SQL Server
SQL Server
Download Photo to a File
See more Facebook Examples
Assuming we have the ID of a Photo, this example demonstrates how to download the photo image data to a file.Chilkat SQL Server Downloads
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls.
--
CREATE PROCEDURE ChilkatSample
AS
BEGIN
DECLARE @hr int
DECLARE @iTmp0 int
-- Important: Do not use nvarchar(max). See the warning about using nvarchar(max).
DECLARE @sTmp0 nvarchar(4000)
DECLARE @success int
SELECT @success = 0
-- This example requires the Chilkat API to have been previously unlocked.
-- See Global Unlock Sample for sample code.
-- This example assumes a previously obtained an access token
DECLARE @oauth2 int
EXEC @hr = sp_OACreate 'Chilkat.OAuth2', @oauth2 OUT
IF @hr <> 0
BEGIN
PRINT 'Failed to create ActiveX component'
RETURN
END
EXEC sp_OASetProperty @oauth2, 'AccessToken', 'FACEBOOK-ACCESS-TOKEN'
DECLARE @rest int
EXEC @hr = sp_OACreate 'Chilkat.Rest', @rest OUT
-- Connect to Facebook...
EXEC sp_OAMethod @rest, 'Connect', @success OUT, 'graph.facebook.com', 443, 1, 1
IF @success <> 1
BEGIN
EXEC sp_OAGetProperty @rest, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @oauth2
EXEC @hr = sp_OADestroy @rest
RETURN
END
-- Provide the authentication credentials (i.e. the access key)
EXEC sp_OAMethod @rest, 'SetAuthOAuth2', @success OUT, @oauth2
-- Assumes we've already obtained a Photo ID.
DECLARE @photoId nvarchar(4000)
SELECT @photoId = '10210199026347451'
DECLARE @sbPath int
EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbPath OUT
EXEC sp_OAMethod @sbPath, 'Append', @success OUT, '/v2.7/'
EXEC sp_OAMethod @sbPath, 'Append', @success OUT, @photoId
-- First we're going to get the photo informaton so we can get the URL of the image file data.
-- Select the fields we want.
-- See https://developers.facebook.com/docs/graph-api/reference/photo/
EXEC sp_OAMethod @rest, 'AddQueryParam', @success OUT, 'fields', 'id,album,images'
DECLARE @responseJson nvarchar(4000)
EXEC sp_OAMethod @sbPath, 'GetAsString', @sTmp0 OUT
EXEC sp_OAMethod @rest, 'FullRequestNoBody', @responseJson OUT, 'GET', @sTmp0
EXEC sp_OAGetProperty @rest, 'LastMethodSuccess', @iTmp0 OUT
IF @iTmp0 <> 1
BEGIN
EXEC sp_OAGetProperty @rest, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @oauth2
EXEC @hr = sp_OADestroy @rest
EXEC @hr = sp_OADestroy @sbPath
RETURN
END
DECLARE @json int
EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @json OUT
EXEC sp_OASetProperty @json, 'EmitCompact', 0
EXEC sp_OAMethod @json, 'Load', @success OUT, @responseJson
-- Show the JSON in human-readable format.
EXEC sp_OAMethod @json, 'Emit', @sTmp0 OUT
PRINT @sTmp0
-- Get the image URL.
DECLARE @imageUrl nvarchar(4000)
EXEC sp_OAMethod @json, 'StringOf', @imageUrl OUT, 'images[0].source'
PRINT 'Downloading from ' + @imageUrl
DECLARE @sbImageUrl int
EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbImageUrl OUT
EXEC sp_OAMethod @sbImageUrl, 'Append', @success OUT, @imageUrl
-- Build the output local file path.
DECLARE @sbToPath int
EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbToPath OUT
EXEC sp_OAMethod @sbToPath, 'Append', @success OUT, 'qa_output/fb'
EXEC sp_OAMethod @json, 'StringOf', @sTmp0 OUT, 'id'
EXEC sp_OAMethod @sbToPath, 'Append', @success OUT, @sTmp0
DECLARE @bCaseSensitive int
SELECT @bCaseSensitive = 0
EXEC sp_OAMethod @sbImageUrl, 'Contains', @iTmp0 OUT, '.jpg', @bCaseSensitive
IF @iTmp0 = 1
BEGIN
EXEC sp_OAMethod @sbToPath, 'Append', @success OUT, '.jpg'
END
ELSE
BEGIN
EXEC sp_OAMethod @sbToPath, 'Append', @success OUT, '.png'
END
EXEC sp_OAMethod @sbToPath, 'GetAsString', @sTmp0 OUT
PRINT 'Downloading to ' + @sTmp0
-- Download using Chilkat HTTP.
DECLARE @http int
EXEC @hr = sp_OACreate 'Chilkat.Http', @http OUT
EXEC sp_OAMethod @sbToPath, 'GetAsString', @sTmp0 OUT
EXEC sp_OAMethod @http, 'Download', @success OUT, @imageUrl, @sTmp0
IF @success <> 1
BEGIN
EXEC sp_OAGetProperty @http, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
END
ELSE
BEGIN
PRINT 'Downloaded.'
END
EXEC @hr = sp_OADestroy @oauth2
EXEC @hr = sp_OADestroy @rest
EXEC @hr = sp_OADestroy @sbPath
EXEC @hr = sp_OADestroy @json
EXEC @hr = sp_OADestroy @sbImageUrl
EXEC @hr = sp_OADestroy @sbToPath
EXEC @hr = sp_OADestroy @http
END
GO