You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							73 lines
						
					
					
						
							2.3 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							73 lines
						
					
					
						
							2.3 KiB
						
					
					
				| package main | |
| 
 | |
| import ( | |
| 	"github.com/aws/aws-sdk-go/aws" | |
| 	"github.com/aws/aws-sdk-go/aws/session" | |
| 	"github.com/aws/aws-sdk-go/service/s3" | |
| 	"encoding/base64" | |
| 	"fmt" | |
| 	"crypto/md5" | |
| 	"strings" | |
| 	"time" | |
| 	"net/http" | |
| ) | |
| 
 | |
| // Downloads an item from an S3 Bucket in the region configured in the shared config | |
| // or AWS_REGION environment variable. | |
| // | |
| // Usage: | |
| //     go run presigned_put.go | |
| // For this exampl to work, the domainName is needd | |
| //     weed s3 -domainName=localhost | |
| func main() { | |
| 	h := md5.New() | |
| 	content := strings.NewReader(stringContent) | |
| 	content.WriteTo(h) | |
| 
 | |
| 	// Initialize a session in us-west-2 that the SDK will use to load | |
| 	// credentials from the shared credentials file ~/.aws/credentials. | |
| 	sess, err := session.NewSession(&aws.Config{ | |
| 		Region:   aws.String("us-east-1"), | |
| 		Endpoint: aws.String("http://localhost:8333"), | |
| 	}) | |
| 
 | |
| 	// Create S3 service client | |
| 	svc := s3.New(sess) | |
| 
 | |
| 	putRequest, output := svc.PutObjectRequest(&s3.PutObjectInput{ | |
| 		Bucket: aws.String("dev"), | |
| 		Key:    aws.String("testKey"), | |
| 	}) | |
| 	fmt.Printf("output: %+v\n", output) | |
| 
 | |
| 	md5s := base64.StdEncoding.EncodeToString(h.Sum(nil)) | |
| 	putRequest.HTTPRequest.Header.Set("Content-MD5", md5s) | |
| 
 | |
| 	url, err := putRequest.Presign(15 * time.Minute) | |
| 	if err != nil { | |
| 		fmt.Println("error presigning request", err) | |
| 		return | |
| 	} | |
| 
 | |
| 	fmt.Println(url) | |
| 
 | |
| 	req, err := http.NewRequest("PUT", url, strings.NewReader(stringContent)) | |
| 	req.Header.Set("Content-MD5", md5s) | |
| 	if err != nil { | |
| 		fmt.Println("error creating request", url) | |
| 		return | |
| 	} | |
| 
 | |
| 	resp, err := http.DefaultClient.Do(req) | |
| 	if err != nil { | |
| 		fmt.Printf("error put request: %v\n", err) | |
| 		return | |
| 	} | |
| 	fmt.Printf("response: %+v\n", resp) | |
| } | |
| 
 | |
| var stringContent = `Generate a Pre-Signed URL for an Amazon S3 PUT Operation with a Specific Payload | |
| You can generate a pre-signed URL for a PUT operation that checks whether users upload the correct content. When the SDK pre-signs a request, it computes the checksum of the request body and generates an MD5 checksum that is included in the pre-signed URL. Users must upload the same content that produces the same MD5 checksum generated by the SDK; otherwise, the operation fails. This is not the Content-MD5, but the signature. To enforce Content-MD5, simply add the header to the request. | |
|  | |
| The following example adds a Body field to generate a pre-signed PUT operation that requires a specific payload to be uploaded by users. | |
| `
 |