इस पेज पर, Tenor एपीआई के ज़रिए उपलब्ध होने वाले हर एंडपॉइंट की जानकारी मिलती है. हर एंडपॉइंट के लिए, यह पेज नीचे दी गई जानकारी देता है:
- इस्तेमाल किया जाने वाला बेस यूआरएल
- सबसे सही तरीके
- उपलब्ध पैरामीटर
- रिस्पॉन्स फ़ॉर्मैट
- हर भाषा में अनुरोधों के उदाहरण
खोजें
मूल URL
https://tenor.googleapis.com/v2/search?<parameters>
JSON के ऑब्जेक्ट का इस्तेमाल करके, खोज के लिए शब्दों, कैटगरी, इमोजी या इन कॉम्बिनेशन के किसी सेट के लिए सबसे ज़्यादा काम के GIF की सूची पाएं.
अनुरोध में यूआरएल पैरामीटर searchfilter=sticker
को शामिल करने पर, Tenor का खोज एंडपॉइंट, GIF की जगह स्टिकर दिखाता है. स्टिकर के खोज नतीजों में दिए गए
रिस्पॉन्स ऑब्जेक्ट में, media_formats
फ़ील्ड में पारदर्शी फ़ॉर्मैट शामिल होते हैं.
नतीजों को बिना किसी क्रम के दिखाने के लिए, यूआरएल पैरामीटर को क्रम में लगाने के बजाय random=true
यूआरएल पैरामीटर का इस्तेमाल करें.
सबसे सही तरीके
- अपने इंटिग्रेशन को अलग दिखाने के लिए, एपीआई के
key
के साथ-साथclient_key
पैरामीटर दें. - टाइप किए गए तरीके से उपयोगकर्ता की खोज की सुविधा दें. इसमें विराम चिह्न और खास वर्ण शामिल होने चाहिए.
- अगर कोई उपयोगकर्ता यह तय करता है कि किस GIF या स्टिकर को शेयर करना है, तो हम शेयर करने के लिए रजिस्टर करें एंडपॉइंट पर उससे जुड़ा कॉल भी शामिल करने का सुझाव देते हैं. इस वैकल्पिक कॉल से, Tenor के सर्च इंजन एआई (AI) को बेहतर नतीजे पाने में मदद मिलती है.
- GIF की रकम और फ़्लो को कंट्रोल करने के लिए,
limit
औरpos
पैरामीटर का इस्तेमाल करें. उदाहरण के लिए, आपके पास उपयोगकर्ता के शुरुआती खोज नतीजों के लिएlimit = 10
सेट करने और उन GIF की झलक लोड करने का विकल्प होता है, ताकि उपयोगकर्ता उन्हें ब्राउज़ कर सके. अगर उपयोगकर्ता ज़्यादा नतीजे पाने के लिए अनुरोध करता है, तो अगले 10 नतीजे इकट्ठा करें. इसके लिए, पहले एक ही एपीआई कॉल करें. इसके लिए, शुरुआती जवाब में,pos
कोnext
फ़ील्ड की वैल्यू पर सेट करें. इस पैटर्न का इस्तेमाल करके, लेज़ी लोडिंग का अनुभव लिया जा सकता है. इससे बैंडविड्थ का इस्तेमाल कम रहता है और उपयोगकर्ता को फटाफट जवाब मिलने में ज़्यादा समय लगता है. ऐसा इसलिए होता है, क्योंकि क्लाइंट की तरफ़ से कम GIF की झलक ही लोड होती है. - GIF के लिए इंटरनल कॉन्टेंट की सुरक्षा रेटिंग बनाए रखने के लिए,
ContentFilter
पैरामीटर का इस्तेमाल करें. डिफ़ॉल्ट वैल्यूoff
है. - दिखाए गए कॉन्टेंट फ़ॉर्मैट की संख्या को कम करने के लिए,
media_filter
पैरामीटर का इस्तेमाल करें. इससे, रिस्पॉन्स ऑब्जेक्ट का साइज़ 70% से ज़्यादा कम हो सकता है.
पैरामीटर में
इस टेबल में, खोज एंडपॉइंट के पैरामीटर की जानकारी दी गई है:
पैरामीटर में | |
---|---|
key |
ज़रूरी
खास अधिकारों वाले ऐक्सेस के लिए एपीआई पासकोड डिफ़ॉल्ट वैल्यू नहीं है. |
q |
ज़रूरी
खोज स्ट्रिंग डिफ़ॉल्ट वैल्यू नहीं है. |
client_key |
खास तौर पर सुझाया गया
क्लाइंट के हिसाब से स्ट्रिंग, जो इंटिग्रेशन की जानकारी देती है. क्लाइंट कुंजी की मदद से, अलग-अलग इंटिग्रेशन में एक ही एपीआई कुंजी का इस्तेमाल किया जा सकता है. हालांकि, ऐसा करने के बाद भी उनमें अंतर किया जा सकता है. ऐप्लिकेशन इंटिग्रेशन के लिए, सभी एपीआई कॉल के लिए एक ही कोई भी क्लाइंट कस्टम व्यवहार डिफ़ॉल्ट वैल्यू नहीं है. |
searchfilter |
ज़रूरी नहीं
रिस्पॉन्स ऑब्जेक्ट को फ़िल्टर करने के लिए, GIF के अलावा दूसरी तरह के कॉन्टेंट की सूची जिसे कॉमा लगाकर अलग किया गया है. डिफ़ॉल्ट रूप से, डिफ़ॉल्ट वैल्यू नहीं है.
|
country |
खास तौर पर सुझाया गया
अनुरोध करने के लिए, टारगेट किए जाने वाले देश का नाम बताएं. ऐसा करने के लिए, इसका दो अक्षरों वाला ISO 3166-1 देश कोड दें. डिफ़ॉल्ट वैल्यू |
locale |
खास तौर पर सुझाया गया
खोज स्ट्रिंग को समझने के लिए, डिफ़ॉल्ट भाषा तय करें.
डिफ़ॉल्ट वैल्यू |
contentfilter |
खास तौर पर सुझाया गया
कॉन्टेंट की सुरक्षा वाले फ़िल्टर के लेवल के बारे में बताएं. डिफ़ॉल्ट वैल्यू |
media_filter |
खास तौर पर सुझाया गया
रिस्पॉन्स ऑब्जेक्ट को फ़िल्टर करने के लिए, GIF फ़ॉर्मैट की कॉमा-सेपरेटेड लिस्ट. डिफ़ॉल्ट रूप से, उदाहरण: डिफ़ॉल्ट वैल्यू नहीं है. |
ar_range |
खास तौर पर सुझाया गया
रिस्पॉन्स ऑब्जेक्ट को इस तरह फ़िल्टर करें कि सिर्फ़ वही आसपेक्ट रेशियो (चौड़ाई-ऊंचाई का अनुपात) वाले GIF शामिल हों जो चुनी गई रेंज में फ़िट हों. डिफ़ॉल्ट वैल्यू
|
random |
ज़रूरी नहीं
बताएं कि जवाब को किसी भी क्रम में लगाना है या नहीं. डिफ़ॉल्ट वैल्यू स्वीकार की गई वैल्यू |
limit |
ज़रूरी नहीं
तय संख्या तक नतीजे पाएं. डिफ़ॉल्ट वैल्यू |
pos |
ज़रूरी नहीं
"वैल्यू" स्थिति से शुरू होने वाले नतीजे फिर से पाएं. नतीजों के अगले सेट के लिए, एपीआई से मिले डिफ़ॉल्ट वैल्यू नहीं है. |
जवाब का फ़ॉर्मैट
नीचे दी गई टेबल, खोज एंडपॉइंट के रिस्पॉन्स फ़ॉर्मैट के बारे में जानकारी देती है:
सुरक्षा कुंजी | |
---|---|
next |
नतीजों के अगले सेट को पाने के लिए, अगली एपीआई क्वेरी के ज़रिए |
results |
रिस्पॉन्स ऑब्जेक्ट की कैटगरी, जिसमें खोज के लिए इस्तेमाल किए गए शब्द के लिए, सबसे काम का कॉन्टेंट शामिल है. कॉन्टेंट को उसके काम की रैंक के हिसाब से क्रम में लगाया जाता है. |
अनुरोध के उदाहरण
कर्ल
/* search for excited top 8 GIFs */
curl "https://tenor.googleapis.com/v2/search?q=excited&key=API_KEY&client_key=my_test_app&limit=8"
Python
# set the apikey and limit
apikey = "API_KEY" # click to set to your apikey
lmt = 8
ckey = "my_test_app" # set the client_key for the integration and use the same value for all API calls
# our test search
search_term = "excited"
# get the top 8 GIFs for the search term
r = requests.get(
"https://tenor.googleapis.com/v2/search?q=%s&key=%s&client_key=%s&limit=%s" % (search_term, apikey, ckey, lmt))
if r.status_code == 200:
# load the GIFs using the urls for the smaller GIF sizes
top_8gifs = json.loads(r.content)
print(top_8gifs)
else:
top_8gifs = None
Android/Java
import android.app.Application;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.BufferedInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.StringWriter;
import java.net.ConnectException;
import java.net.HttpURLConnection;
import java.net.URL;
public class App extends Application {
private static final String API_KEY = "API_KEY";
private static final String CLIENT_KEY = "my_test_app"
private static final String LogTag = "TenorTest";
@Override
public void onCreate() {
super.onCreate();
new Thread() {
@Override
public void run() {
final String searchTerm = "excited";
// make initial search request for the first 8 items
JSONObject searchResult = getSearchResults(searchTerm, 8);
// load the results for the user
Log.v(LogTag, "Search Results: " + searchResult.toString());
}
}.start();
}
/**
* Get Search Result GIFs
*/
public static JSONObject getSearchResults(String searchTerm, int limit) {
// make search request - using default locale of EN_US
final String url = String.format("https://tenor.googleapis.com/v2/search?q=%1$s&key=%2$s&client_key=%3$s&limit=%4$s",
searchTerm, API_KEY, CLIENT_KEY, limit);
try {
return get(url);
} catch (IOException | JSONException ignored) {
}
return null;
}
/**
* Construct and run a GET request
*/
private static JSONObject get(String url) throws IOException, JSONException {
HttpURLConnection connection = null;
try {
// Get request
connection = (HttpURLConnection) new URL(url).openConnection();
connection.setDoInput(true);
connection.setDoOutput(true);
connection.setRequestMethod("GET");
connection.setRequestProperty("Content-Type", "application/json");
connection.setRequestProperty("Accept", "application/json");
connection.setRequestProperty("Content-Type", "application/json; charset=UTF-8");
// Handle failure
int statusCode = connection.getResponseCode();
if (statusCode != HttpURLConnection.HTTP_OK && statusCode != HttpURLConnection.HTTP_CREATED) {
String error = String.format("HTTP Code: '%1$s' from '%2$s'", statusCode, url);
throw new ConnectException(error);
}
// Parse response
return parser(connection);
} catch (Exception ignored) {
} finally {
if (connection != null) {
connection.disconnect();
}
}
return new JSONObject("");
}
/**
* Parse the response into JSONObject
*/
private static JSONObject parser(HttpURLConnection connection) throws JSONException {
char[] buffer = new char[1024 * 4];
int n;
InputStream stream = null;
try {
stream = new BufferedInputStream(connection.getInputStream());
InputStreamReader reader = new InputStreamReader(stream, "UTF-8");
StringWriter writer = new StringWriter();
while (-1 != (n = reader.read(buffer))) {
writer.write(buffer, 0, n);
}
return new JSONObject(writer.toString());
} catch (IOException ignored) {
} finally {
if (stream != null) {
try {
stream.close();
} catch (IOException ignored) {
}
}
}
return new JSONObject("");
}
}
Swift 2.0+/iOS
let apikey = "API_KEY"
let clientkey = "my_test_app"
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
requestData()
return true
}
/**
Execute web request to retrieve the top GIFs returned (in batches of 8) for the given search term.
*/
func requestData()
{
// the test search term
let searchTerm = "excited"
// Define the results upper limit
let limit = 8
// make initial search request for the first 8 items
let searchRequest = URLRequest(url: URL(string: String(format: "https://tenor.googleapis.com/v2/search?q=%@&key=%@&client_key=%@&limit=%d",
searchTerm,
apikey,
clientkey,
limit))!)
makeWebRequest(urlRequest: searchRequest, callback: tenorSearchHandler)
// Data will be loaded by each request's callback
}
/**
Async URL requesting function.
*/
func makeWebRequest(urlRequest: URLRequest, callback: @escaping ([String:AnyObject]) -> ())
{
// Make the async request and pass the resulting JSON object to the callback
let task = URLSession.shared.dataTask(with: urlRequest) { (data, response, error) in
do {
if let jsonResult = try JSONSerialization.jsonObject(with: data!, options: []) as? [String:AnyObject] {
// Push the results to our callback
callback(jsonResult)
}
} catch let error as NSError {
print(error.localizedDescription)
}
}
task.resume()
}
/**
Web response handler for search requests.
*/
func tenorSearchHandler(response: [String:AnyObject])
{
// Parse the JSON response
let responseGifs = response["results"]!
// Load the GIFs into your view
print("Result GIFS: (responseGifs)")
}
}
JavaScript
<!DOCTYPE html>
<html>
<script>
// url Async requesting function
function httpGetAsync(theUrl, callback)
{
// create the request object
var xmlHttp = new XMLHttpRequest();
// set the state change callback to capture when the response comes in
xmlHttp.onreadystatechange = function()
{
if (xmlHttp.readyState == 4 && xmlHttp.status == 200)
{
callback(xmlHttp.responseText);
}
}
// open as a GET call, pass in the url and set async = True
xmlHttp.open("GET", theUrl, true);
// call send with no params as they were passed in on the url string
xmlHttp.send(null);
return;
}
// callback for the top 8 GIFs of search
function tenorCallback_search(responsetext)
{
// Parse the JSON response
var response_objects = JSON.parse(responsetext);
top_10_gifs = response_objects["results"];
// load the GIFs -- for our example we will load the first GIFs preview size (nanogif) and share size (gif)
document.getElementById("preview_gif").src = top_10_gifs[0]["media_formats"]["nanogif"]["url"];
document.getElementById("share_gif").src = top_10_gifs[0]["media_formats"]["gif"]["url"];
return;
}
// function to call the trending and category endpoints
function grab_data()
{
// set the apikey and limit
var apikey = "API_KEY";
var clientkey = "my_test_app";
var lmt = 8;
// test search term
var search_term = "excited";
// using default locale of en_US
var search_url = "https://tenor.googleapis.com/v2/search?q=" + search_term + "&key=" +
apikey +"&client_key=" + clientkey + "&limit=" + lmt;
httpGetAsync(search_url,tenorCallback_search);
// data will be loaded by each call's callback
return;
}
// SUPPORT FUNCTIONS ABOVE
// MAIN BELOW
// start the flow
grab_data();
</script>
<body>
<h2># 1 GIF loaded - preview image</h2>
<img id="preview_gif" src="" alt="" style="width:220px;height:164px;">
<h2># 1 GIF loaded - share image</h2>
<img id="share_gif" src="" alt="" style="width:498px;height:372px;">
</body>
</html>
Objective-C
NSString *apiKey = @"API_KEY";
NSString *clientKey = @"my_test_app";
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
[self requestData];
return YES;
}
/**
Execute web request to retrieve the top GIFs returned(in batches of 8) for the given search term.
*/
-(void)requestData
{
// Define the results upper limit
int limit = 8;
// the test search term
NSString *searchQuery = @"excited";
// Get the top 10 trending GIFs (updated through out the day) - using the default locale of en_US
NSString *UrlString = [NSString stringWithFormat:@"https://tenor.googleapis.com/v2/search?key=%@&client_key=%@&q=%@&limit=%d", apiKey, clientKey, searchQuery, limit];
NSURL *searchUrl = [NSURL URLWithString:UrlString];
NSURLRequest *searchRequest = [NSURLRequest requestWithURL:searchUrl];
[self makeWebRequest:searchRequest withCallback:tenorSearchResultsHandler];
// Data will be loaded by each request's callback
}
/**
Async URL requesting function.
*/
-(void)makeWebRequest:(NSURLRequest *)urlRequest withCallback:(void (^)(NSDictionary *))callback
{
// Make the async request and pass the resulting JSON object to the callback
NSURLSessionTask *task = [[NSURLSession sharedSession] dataTaskWithRequest:urlRequest completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) {
NStopGifsError *jsonError = nil;
NSDictionary *jsonResult = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableLeaves error:&jsonError];
if(jsonError != nil) {
NSLog(@"%@", jsonError.localizedDescription);
return;
}
// Push the results to our callback
callback(jsonResult);
}];
[task resume];
}
/**
Web response handler for searches.
*/
void (^tenorSearchResultsHandler)(NSDictionary *) = ^void(NSDictionary *response)
{
// Parse the JSON response
NSDictionary *topGifs = response[@"results"];
// Load the GIFs into your view
NSLog(@"Search Results: %@", topGifs);
};
चुनिंदा
मूल URL
https://tenor.googleapis.com/v2/featured?<parameters>
JSON ऑब्जेक्ट पाएं, जिसमें दुनिया भर में दिखाए जाने वाले मौजूदा GIF की सूची मौजूद हो. Tenor, चुनी गई स्ट्रीम को दिन भर अपडेट करता रहता है.
जब यूआरएल पैरामीटर searchfilter=sticker
को अनुरोध में शामिल किया जाता है, तो Tenor का फ़ीचर्ड एंडपॉइंट, GIF के बजाय स्टिकर दिखाता है. स्टिकर में दिखाए गए
जवाब,
रिस्पॉन्स ऑब्जेक्ट के साथ media
फ़ील्ड में पारदर्शी
फ़ॉर्मैट
शामिल करें.
सबसे सही तरीके
- अपने इंटिग्रेशन को अलग दिखाने के लिए, एपीआई के
key
के साथ-साथclient_key
पैरामीटर दें. - अगर कोई उपयोगकर्ता यह तय करता है कि किस GIF या स्टिकर को शेयर करना है, तो हम शेयर करने के लिए रजिस्टर करें एंडपॉइंट पर उससे जुड़ा कॉल भी शामिल करने का सुझाव देते हैं. इस वैकल्पिक कॉल से, Tenor के सर्च इंजन एआई (AI) को बेहतर नतीजे पाने में मदद मिलती है.
- GIF के लोड होने और उनके फ़्लो को कंट्रोल करने के लिए,
limit
औरpos
पैरामीटर का इस्तेमाल करें. उदाहरण के लिए,limit = 10
को उपयोगकर्ता के शुरुआती रुझान वाले अनुरोध के नतीजों के लिए सेट किया जा सकता है. साथ ही, उपयोगकर्ता के ब्राउज़ करने के लिए, इन GIF की झलक लोड की जा सकती है. अगर उपयोगकर्ता ज़्यादा नतीजे दिखाने का अनुरोध करता है, तो अगले 10 नतीजे इकट्ठा करें. इसके लिए, उसी एपीआई कॉल का इस्तेमाल करें औरpos
शुरुआती जवाब मेंnext
फ़ील्ड की वैल्यू पर सेट करें. इस पैटर्न का इस्तेमाल करके, लेज़ी लोडिंग का अनुभव लिया जा सकता है. इससे बैंडविड्थ का इस्तेमाल कम रहता है और उपयोगकर्ता को फटाफट जवाब मिलने में ज़्यादा समय लगता है. ऐसा इसलिए होता है, क्योंकि क्लाइंट की तरफ़ से कम GIF की झलक ही लोड होती है. - अपनी सेवा या ऐप्लिकेशन के लिए, GIF कॉन्टेंट की सुरक्षा की सही रेटिंग बताने के लिए,
ContentFilter
पैरामीटर का इस्तेमाल करें. - GIF फ़ॉर्मैट की संख्या कम करने के लिए,
media_filter
पैरामीटर का इस्तेमाल करें. इससे, रिस्पॉन्स ऑब्जेक्ट का साइज़ 75% कम हो सकता है.
पैरामीटर में
इस टेबल में, एंडपॉइंट के पैरामीटर की जानकारी दी गई है:
पैरामीटर में | |
---|---|
key |
ज़रूरी
खास अधिकारों वाले एपीआई के ऐक्सेस के लिए एपीआई कुंजी डिफ़ॉल्ट वैल्यू नहीं है. |
client_key |
खास तौर पर सुझाया गया
क्लाइंट के हिसाब से स्ट्रिंग, जो इंटिग्रेशन की जानकारी देती है. क्लाइंट कुंजी की मदद से, अलग-अलग इंटिग्रेशन में एक ही एपीआई कुंजी का इस्तेमाल किया जा सकता है. हालांकि, ऐसा करने के बाद भी उनमें अंतर किया जा सकता है. ऐप्लिकेशन इंटिग्रेशन के लिए, सभी एपीआई कॉल के लिए एक ही क्लाइंट का कोई भी कस्टम व्यवहार, डिफ़ॉल्ट वैल्यू नहीं है. |
searchfilter |
ज़रूरी नहीं
रिस्पॉन्स ऑब्जेक्ट को फ़िल्टर करने के लिए, GIF के अलावा दूसरी तरह के कॉन्टेंट की सूची जिसे कॉमा लगाकर अलग किया गया है. डिफ़ॉल्ट रूप से, डिफ़ॉल्ट वैल्यू नहीं है. स्वीकार की जाने वाली वैल्यू
|
country |
खास तौर पर सुझाया गया
अनुरोध करने के लिए, टारगेट किए जाने वाले देश का नाम बताएं. ऐसा करने के लिए, इसका दो अक्षरों वाला ISO 3166-1 देश कोड दें. डिफ़ॉल्ट वैल्यू |
locale |
खास तौर पर सुझाया गया
खोज स्ट्रिंग को समझने के लिए, डिफ़ॉल्ट भाषा तय करें.
डिफ़ॉल्ट वैल्यू |
media_filter |
खास तौर पर सुझाया गया
रिस्पॉन्स ऑब्जेक्ट को फ़िल्टर करने के लिए, GIF फ़ॉर्मैट की कॉमा-सेपरेटेड लिस्ट. डिफ़ॉल्ट रूप से, उदाहरण: डिफ़ॉल्ट वैल्यू नहीं है. |
ar_range |
खास तौर पर सुझाया गया
रिस्पॉन्स ऑब्जेक्ट को इस तरह फ़िल्टर करें कि सिर्फ़ वही आसपेक्ट रेशियो (चौड़ाई-ऊंचाई का अनुपात) वाले GIF शामिल हों जो चुनी गई रेंज में फ़िट हों. डिफ़ॉल्ट वैल्यू
|
contentfilter |
खास तौर पर सुझाया गया
कॉन्टेंट की सुरक्षा वाले फ़िल्टर के लेवल के बारे में बताएं. डिफ़ॉल्ट वैल्यू |
limit |
ज़रूरी नहीं
तय संख्या तक नतीजे पाएं. डिफ़ॉल्ट वैल्यू |
pos |
ज़रूरी नहीं
"वैल्यू" स्थिति से शुरू होने वाले नतीजे फिर से पाएं. नतीजों के अगले सेट के लिए, एपीआई से मिले डिफ़ॉल्ट वैल्यू नहीं है. |
जवाब का फ़ॉर्मैट
इस टेबल में, एंडपॉइंट के रिस्पॉन्स फ़ॉर्मैट के बारे में जानकारी दी गई है:
सुरक्षा कुंजी | |
---|---|
next |
नतीजों के अगले सेट को पाने के लिए, अगली एपीआई क्वेरी के ज़रिए |
results |
चुनिंदा रिस्पॉन्स ऑब्जेक्ट की कैटगरी. |
अनुरोध के उदाहरण
कर्ल
/* Featured GIFs call */
curl "https://tenor.googleapis.com/v2/featured?key=API_KEY&client_key=my_test_app"
Python
import requests
import json
# set the apikey and limit
apikey = "API_KEY" # click to set to your apikey
ckey = "my_test_app" # set the client_key for the integration
lmt = 10
# get the top 10 featured GIFs - using the default locale of en_US
r = requests.get("https://tenor.googleapis.com/v2/featured?key=%s&client_key=%s&limit=%s" % (apikey, ckey, lmt))
if r.status_code == 200:
featured_gifs = json.loads(r.content)
else:
featured_gifs = None
# load the featured GIFs
print (featured_gifs)
Android/Java
import android.app.Application;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.BufferedInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.StringWriter;
import java.net.ConnectException;
import java.net.HttpURLConnection;
import java.net.URL;
public class App extends Application {
private static final String API_KEY = "API_KEY";
private static final String CLIENT_KEY = "my_test_app";
private static final String LogTag = "TenorTest";
@Override
public void onCreate() {
super.onCreate();
new Thread() {
@Override
public void run() {
// get the top 10 featured GIFs
JSONObject featuredGifs = getFeaturedGifs(10);
// load the results for the user
Log.v(LogTag, "Featured GIFS: " + featuredGifs.toString());
}
}.start();
}
/**
* Get featured GIFs
*/
public static JSONObject getFeaturedGifs(int limit) {
// get the Featured GIFS - using the default locale of en_US
final String url = String.format("https://tenor.googleapis.com/v2/featured?key=%1$s&client_key=%2$s&limit=%3$s",
API_KEY, CLIENT_KEY, limit);
try {
return get(url);
} catch (IOException | JSONException ignored) {
}
return null;
}
/**
* Construct and run a GET request
*/
private static JSONObject get(String url) throws IOException, JSONException {
HttpURLConnection connection = null;
try {
// Get request
connection = (HttpURLConnection) new URL(url).openConnection();
connection.setDoInput(true);
connection.setDoOutput(true);
connection.setRequestMethod("GET");
connection.setRequestProperty("Content-Type", "application/json");
connection.setRequestProperty("Accept", "application/json");
connection.setRequestProperty("Content-Type", "application/json; charset=UTF-8");
// Handle failure
int statusCode = connection.getResponseCode();
if (statusCode != HttpURLConnection.HTTP_OK && statusCode != HttpURLConnection.HTTP_CREATED) {
String error = String.format("HTTP Code: '%1$s' from '%2$s'", statusCode, url);
throw new ConnectException(error);
}
// Parse response
return parser(connection);
} catch (Exception ignored) {
} finally {
if (connection != null) {
connection.disconnect();
}
}
return new JSONObject("");
}
/**
* Parse the response into JSONObject
*/
private static JSONObject parser(HttpURLConnection connection) throws JSONException {
char[] buffer = new char[1024 * 4];
int n;
InputStream stream = null;
try {
stream = new BufferedInputStream(connection.getInputStream());
InputStreamReader reader = new InputStreamReader(stream, "UTF-8");
StringWriter writer = new StringWriter();
while (-1 != (n = reader.read(buffer))) {
writer.write(buffer, 0, n);
}
return new JSONObject(writer.toString());
} catch (IOException ignored) {
} finally {
if (stream != null) {
try {
stream.close();
} catch (IOException ignored) {
}
}
}
return new JSONObject("");
}
}
Swift 2.0+/iOS
let apikey = "API_KEY"
let clientkey = "my_test_app"
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
requestData()
return true
}
/**
Execute web requests to retrieve featured GIFs
*/
func requestData()
{
// Define the results upper limit
let limit = 10
// Get the top 10 featured GIFs (updated throughout the day) - using the default locale of en_US
let featuredRequest = URLRequest(url: URL(string: String(format: "https://tenor.googleapis.com/v2/featured?key=%@&client_key=%@&limit=%d",
apikey,
clientkey,
limit))!)
makeWebRequest(urlRequest: featuredRequest, callback: tenorFeaturedResultsHandler)
// Data will be loaded by the request's callback
}
/**
Async URL requesting function.
*/
func makeWebRequest(urlRequest: URLRequest, callback: @escaping ([String:AnyObject]) -> ())
{
// Make the async request and pass the resulting JSON object to the callback
let task = URLSession.shared.dataTask(with: urlRequest) { (data, response, error) in
do {
if let jsonResult = try JSONSerialization.jsonObject(with: data!, options: []) as? [String:AnyObject] {
// Push the results to our callback
callback(jsonResult)
}
} catch let error as NSError {
print(error.localizedDescription)
}
}
task.resume()
}
/**
Web response handler for featured top 10 GIFs.
*/
func tenorFeaturedResultsHandler(response: [String:AnyObject])
{
// Parse the JSON response
let topTenGifs = response["results"]!
// Load the GIFs into your view
print("Featured Results: (topTenGifs)")
}
}
JavaScript
<!DOCTYPE html>
<html>
<script>
// url Async requesting function
function httpGetAsync(theUrl, callback)
{
// create the request object
var xmlHttp = new XMLHttpRequest();
// set the state change callback to capture when the response comes in
xmlHttp.onreadystatechange = function()
{
if (xmlHttp.readyState == 4 && xmlHttp.status == 200)
{
callback(xmlHttp.responseText);
}
}
// open as a GET call, pass in the url and set async = True
xmlHttp.open("GET", theUrl, true);
// call send with no params as they were passed in on the url string
xmlHttp.send(null);
return;
}
// callback for featured top 10 GIFs
function tenorCallback_featured(responsetext)
{
// Parse the JSON response
var response_objects = JSON.parse(responsetext);
top_10_gifs = response_objects["results"];
// load the GIFs -- for our example we will load the first GIFs preview size (nanogif) and share size (gif)
document.getElementById("preview_gif").src = top_10_gifs[0]["media_formats"]["nanogif"]["url"];
document.getElementById("share_gif").src = top_10_gifs[0]["media_formats"]["gif"]["url"];
return;
}
// function to call the featured endpoint
function grab_data()
{
// set the apikey and limit
var apikey = "API_KEY";
var clientkey = "my_test_app";
var lmt = 10;
// get the top 10 featured GIFs (updated throughout the day) - using the default locale of en_US
var featured_url = "https://tenor.googleapis.com/v2/featured?key=" + apikey + "&client_key=" + clientkey + "&limit=" + lmt;
httpGetAsync(featured_url,tenorCallback_featured);
// data will be loaded by each call's callback
return;
}
// SUPPORT FUNCTIONS ABOVE
// MAIN BELOW
// start the flow
grab_data();
</script>
<style>
.container {
position: relative;
text-align: center;
color: white;
}
.title {
text-align: center;
}
.centered {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
</style>
<body>
<h2 class="title">GIF loaded - preview image</h2>
<div class="container">
<img id="preview_gif" src="" alt="" style="">
</div>
<h2 class="title">GIF loaded - share image</h2>
<div class="container">
<img id="share_gif" src="" alt="" style="">
</div>
</body>
</html>
Objective-C
NSString *apiKey = @"API_KEY";
NSString *clientKey = @"my_test_app";
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
[self requestData];
return YES;
}
/**
Execute web requests to retrieve featured GIFs
*/
-(void)requestData
{
// Define the results upper limit
int limit = 10;
// Get the top 10 featured GIFs (updated throughout the day) - using the default locale of en_US
NSString *featuredUrlString = [NSString stringWithFormat:@"https://tenor.googleapis.com/v2/featured?key=%@&client_key=%@&limit=%d", apiKey, clientKey, limit];
NSURL *featuredUrl = [NSURL URLWithString:featuredUrlString];
NSURLRequest *featuredRequest = [NSURLRequest requestWithURL:featuredUrl];
[self makeWebRequest:featuredRequest withCallback:tenorFeaturedResultsHandler];
// Data will be loaded by each request's callback
}
/**
Async URL requesting function.
*/
-(void)makeWebRequest:(NSURLRequest *)urlRequest withCallback:(void (^)(NSDictionary *))callback
{
// Make the async request and pass the resulting JSON object to the callback
NSURLSessionTask *task = [[NSURLSession sharedSession] dataTaskWithRequest:urlRequest completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) {
NSError *jsonError = nil;
NSDictionary *jsonResult = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableLeaves error:&jsonError];
if(jsonError != nil) {
NSLog(@"%@", jsonError.localizedDescription);
return;
}
// Push the results to our callback
callback(jsonResult);
}];
[task resume];
}
/**
Web response handler for featured top 10 GIFs.
*/
void (^tenorFeaturedResultsHandler)(NSDictionary *) = ^void(NSDictionary *response)
{
// Parse the JSON response
NSDictionary *topTenGifs = response[@"results"];
// Load the GIFs into your view
NSLog(@"Featured Results: %@", topTenGifs);
};
कैटगरी
मूल URL
https://tenor.googleapis.com/v2/categories?<parameters>
ऐसा JSON ऑब्जेक्ट पाएं जिसमें दिए गए टाइप से जुड़ी GIF कैटगरी की सूची हो. अगर उपयोगकर्ता कैटगरी पर क्लिक करता है, तो हर कैटगरी में उससे जुड़ा एक खोज यूआरएल शामिल होता है. खोज यूआरएल में, मूल कॉल से कैटगरी एंडपॉइंट तक का कोई भी पैरामीटर शामिल होता है.
इस तरह के कोड काम करते हैं
featured
(डिफ़ॉल्ट): GIF या प्रतिक्रिया पर आधारित मौजूदा GIF कैटगरी. इसमें, हर शब्द के लिए झलक दिखाने वाला GIF शामिल होता है.trending
: खोज के लिए हाल ही के रुझान वाले शब्द. इसमें हर शब्द के लिए, झलक दिखाने वाला GIF शामिल होता है.
सबसे सही तरीके
- अपने इंटिग्रेशन को अलग दिखाने के लिए, एपीआई के
key
के साथ-साथclient_key
पैरामीटर दें. - कैटगरी के नामों को उपयोगकर्ता की भाषा में बदलने के लिए,
locale
पैरामीटर का इस्तेमाल करें. डिफ़ॉल्ट वैल्यूen_US
होती है. - अपनी सेवा या ऐप्लिकेशन के लिए, GIF कॉन्टेंट की सुरक्षा की सही रेटिंग बताने के लिए,
ContentFilter
पैरामीटर का इस्तेमाल करें. इस्तेमाल किए जाने पर,ContentFilter
पैरामीटरcategories
रिस्पॉन्स ऑब्जेक्ट में मिलने वाले सभी खोज यूआरएल से होकर गुज़रता है.
पैरामीटर में
नीचे दी गई टेबल में, कैटगरी एंडपॉइंट के पैरामीटर की जानकारी दी गई है:
पैरामीटर में | |
---|---|
key |
ज़रूरी
खास अधिकारों वाले एपीआई के ऐक्सेस के लिए एपीआई कुंजी डिफ़ॉल्ट वैल्यू नहीं है. |
client_key |
खास तौर पर सुझाया गया
क्लाइंट के हिसाब से स्ट्रिंग, जो इंटिग्रेशन की जानकारी देती है. क्लाइंट कुंजी की मदद से, अलग-अलग इंटिग्रेशन में एक ही एपीआई कुंजी का इस्तेमाल किया जा सकता है. हालांकि, ऐसा करने के बाद भी उनमें अंतर किया जा सकता है. ऐप्लिकेशन इंटिग्रेशन के लिए, सभी एपीआई कॉल के लिए एक ही कोई भी क्लाइंट कस्टम व्यवहार डिफ़ॉल्ट वैल्यू नहीं है. |
country |
खास तौर पर सुझाया गया
अनुरोध करने के लिए, टारगेट किए जाने वाले देश का नाम बताएं. ऐसा करने के लिए, इसका दो अक्षरों वाला ISO 3166-1 देश कोड दें. डिफ़ॉल्ट वैल्यू |
locale |
खास तौर पर सुझाया गया
खोज स्ट्रिंग को समझने के लिए, डिफ़ॉल्ट भाषा तय करें.
डिफ़ॉल्ट वैल्यू |
type |
खास तौर पर सुझाया गया
इससे तय होता है कि किस तरह की कैटगरी दी जाती हैं. डिफ़ॉल्ट वैल्यू |
contentfilter |
खास तौर पर सुझाया गया
कॉन्टेंट की सुरक्षा वाले फ़िल्टर के लेवल के बारे में बताएं. डिफ़ॉल्ट वैल्यू |
जवाब का फ़ॉर्मैट
इस टेबल में, कैटगरी एंडपॉइंट के रिस्पॉन्स फ़ॉर्मैट की जानकारी दी गई है:
सुरक्षा कुंजी | |
---|---|
tags |
|
अनुरोध के उदाहरण
कर्ल
/* categories call */
curl "https://tenor.googleapis.com/v2/categories?key=API_KEY&client_key=my_test_app"
Python
import requests
import json
# set the apikey and limit
apikey = "API_KEY" # click to set to your apikey
ckey = "my_test_app" # set the client_key for the integration
# get the current list of categories - using the default locale of en_US
r = requests.get("https://tenor.googleapis.com/v2/categories?key=%s&client_key=%s" % (apikey, ckey))
if r.status_code == 200:
categories = json.loads(r.content)
else:
categories = None
# load the categories below the search bar for the user
print (categories)
Android/Java
import android.app.Application;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.BufferedInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.StringWriter;
import java.net.ConnectException;
import java.net.HttpURLConnection;
import java.net.URL;
public class App extends Application {
private static final String API_KEY = "API_KEY";
private static final String CLIENT_KEY = "my_test_app";
private static final String LogTag = "TenorTest";
@Override
public void onCreate() {
super.onCreate();
new Thread() {
@Override
public void run() {
// get the current list of categories
JSONObject categories = getCategories();
// load the results for the user
Log.v(LogTag, "GIF Categories: " + categories.toString());
}
}.start();
}
/**
* Get categories
*/
public static JSONObject getCategories() {
// get the categories - using the default locale of en_US
final String url = String.format("https://tenor.googleapis.com/v2/categories?key=%1$s&client_key=%2$s",
API_KEY, CLIENT_KEY);
try {
return get(url);
} catch (IOException | JSONException ignored) {
}
return null;
}
/**
* Construct and run a GET request
*/
private static JSONObject get(String url) throws IOException, JSONException {
HttpURLConnection connection = null;
try {
// Get request
connection = (HttpURLConnection) new URL(url).openConnection();
connection.setDoInput(true);
connection.setDoOutput(true);
connection.setRequestMethod("GET");
connection.setRequestProperty("Content-Type", "application/json");
connection.setRequestProperty("Accept", "application/json");
connection.setRequestProperty("Content-Type", "application/json; charset=UTF-8");
// Handle failure
int statusCode = connection.getResponseCode();
if (statusCode != HttpURLConnection.HTTP_OK && statusCode != HttpURLConnection.HTTP_CREATED) {
String error = String.format("HTTP Code: '%1$s' from '%2$s'", statusCode, url);
throw new ConnectException(error);
}
// Parse response
return parser(connection);
} catch (Exception ignored) {
} finally {
if (connection != null) {
connection.disconnect();
}
}
return new JSONObject("");
}
/**
* Parse the response into JSONObject
*/
private static JSONObject parser(HttpURLConnection connection) throws JSONException {
char[] buffer = new char[1024 * 4];
int n;
InputStream stream = null;
try {
stream = new BufferedInputStream(connection.getInputStream());
InputStreamReader reader = new InputStreamReader(stream, "UTF-8");
StringWriter writer = new StringWriter();
while (-1 != (n = reader.read(buffer))) {
writer.write(buffer, 0, n);
}
return new JSONObject(writer.toString());
} catch (IOException ignored) {
} finally {
if (stream != null) {
try {
stream.close();
} catch (IOException ignored) {
}
}
}
return new JSONObject("");
}
}
Swift 2.0+/iOS
let apikey = "API_KEY"
let clientkey = "my_test_app"
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
requestData()
return true
}
/**
Execute web requests to retrieve featured GIFs and GIF categories.
*/
func requestData()
{
// Get the current list of categories - using the default locale of en_US
let categoryRequest = URLRequest(url: URL(string: String(format: "https://tenor.googleapis.com/v2/categories?key=%@&client_key=%@",
apikey, clientkey))!)
makeWebRequest(urlRequest: categoryRequest, callback: tenorCategoryResultsHandler)
// Data will be loaded by each request's callback
}
/**
Async URL requesting function.
*/
func makeWebRequest(urlRequest: URLRequest, callback: @escaping ([String:AnyObject]) -> ())
{
// Make the async request and pass the resulting JSON object to the callback
let task = URLSession.shared.dataTask(with: urlRequest) { (data, response, error) in
do {
if let jsonResult = try JSONSerialization.jsonObject(with: data!, options: []) as? [String:AnyObject] {
// Push the results to our callback
callback(jsonResult)
}
} catch let error as NSError {
print(error.localizedDescription)
}
}
task.resume()
}
/**
Web response handler for GIF categories.
*/
func tenorCategoryResultsHandler(response: [String:AnyObject])
{
// Parse the JSON response
let categories = response["tags"]!
// Load the categories into your view
print("Category Results: (categories)")
}
}
JavaScript
<!DOCTYPE html>
<html>
<script>
// url Async requesting function
function httpGetAsync(theUrl, callback)
{
// create the request object
var xmlHttp = new XMLHttpRequest();
// set the state change callback to capture when the response comes in
xmlHttp.onreadystatechange = function()
{
if (xmlHttp.readyState == 4 && xmlHttp.status == 200)
{
callback(xmlHttp.responseText);
}
}
// open as a GET call, pass in the url and set async = True
xmlHttp.open("GET", theUrl, true);
// call send with no params as they were passed in on the url string
xmlHttp.send(null);
return;
}
// callback for GIF categories
function tenorCallback_categories(responsetext)
{
// Parse the JSON response
var response_objects = JSON.parse(responsetext);
categories = response_objects["tags"];
// load the categories - example is for the first category
// url to load:
var imgurl = categories[0]["image"];
// text to overlay on image:
var txt_overlay = categories[0]["name"];
// search to run if user clicks the category
var category_search_path = categories[0]["path"];
document.getElementById("category_gif").src = imgurl
document.getElementById("catgif_caption").innerHTML = txt_overlay
document.getElementById("cat_link").href = category_search_path
return;
}
// function to call the category endpoints
function grab_data()
{
// set the apikey and limit
var apikey = "API_KEY";
var clientkey = "my_test_app";
// get the current list of categories - using the default locale of en_US
var cat_url = "https://tenor.googleapis.com/v2/categories?key=" + apikey + "&client_key=" + clientkey;
httpGetAsync(cat_url,tenorCallback_categories);
// data will be loaded by each call's callback
return;
}
// SUPPORT FUNCTIONS ABOVE
// MAIN BELOW
// start the flow
grab_data();
</script>
<style>
.container {
position: relative;
text-align: center;
color: white;
}
.title {
text-align: center;
}
.centered {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
</style>
<body>
<h2 class="title">GIF Category</h2>
<div class="container">
<a id="cat_link" href="">
<img id="category_gif" src="" alt="" style="">
<div id="catgif_caption" class="centered"></div>
</a>
</div>
</body>
</html>
Objective-C
NSString *apiKey = @"API_KEY";
NSString *clientKey = @"my_test_app";
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
[self requestData];
return YES;
}
/**
Execute web requests to retrieve GIF categories.
*/
-(void)requestData
{
// Get the current list of categories - using the default locale of en_US
NSString *categoryUrlString = [NSString stringWithFormat:@"https://tenor.googleapis.com/v2/categories?key=%@&client_key=%@", apiKey, clientKey];
NSURL *categoryUrl = [NSURL URLWithString:categoryUrlString];
NSURLRequest *categoryRequest = [NSURLRequest requestWithURL:categoryUrl];
[self makeWebRequest:categoryRequest withCallback:tenorCategoryResultsHandler];
// Data will be loaded by each request's callback
}
/**
Async URL requesting function.
*/
-(void)makeWebRequest:(NSURLRequest *)urlRequest withCallback:(void (^)(NSDictionary *))callback
{
// Make the async request and pass the resulting JSON object to the callback
NSURLSessionTask *task = [[NSURLSession sharedSession] dataTaskWithRequest:urlRequest completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) {
NSError *jsonError = nil;
NSDictionary *jsonResult = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableLeaves error:&jsonError];
if(jsonError != nil) {
NSLog(@"%@", jsonError.localizedDescription);
return;
}
// Push the results to our callback
callback(jsonResult);
}];
[task resume];
}
/**
Web response handler for GIF categories.
*/
void (^tenorCategoryResultsHandler)(NSDictionary *) = ^void(NSDictionary *response)
{
// Parse the JSON response
NSDictionary *categories = response[@"tags"];
// Load the categories into your view
NSLog(@"Category Results: %@", categories);
};
सर्च के सुझाव
मूल URL
https://tenor.googleapis.com/v2/search_suggestions?<parameters>
ऐसा JSON ऑब्जेक्ट पाएं जिसमें खोज के लिए इस्तेमाल किए गए शब्द के लिए, खोज के लिए इस्तेमाल होने वाले वैकल्पिक शब्दों की सूची शामिल हो.
खोज के सुझावों से उपयोगकर्ता को अपनी खोज का दायरा छोटा करने या मिलती-जुलती खोज के लिए शब्द ढूंढने में मदद मिलती है, ताकि वह ज़्यादा सटीक GIF ढूंढ सके. पुराने उपयोगकर्ता की खोज और शेयर करने के तरीके के आधार पर, एपीआई इस हिसाब से नतीजे देता है कि किसी तय किए गए शब्द के लिए, शेयर बढ़ाने की सबसे ज़्यादा संभावना है.
सबसे सही तरीके
- अपने इंटिग्रेशन को अलग दिखाने के लिए, एपीआई के
key
के साथ-साथclient_key
पैरामीटर दें. - नतीजों को उसी क्रम में दिखाएं जिस क्रम में आपने उन्हें अपलोड किया है.
पैरामीटर में
नीचे दी गई टेबल, Search के सुझावों वाले एंडपॉइंट के पैरामीटर की जानकारी देती है:
पैरामीटर में | |
---|---|
key |
ज़रूरी
खास अधिकारों वाले एपीआई के ऐक्सेस के लिए एपीआई कुंजी डिफ़ॉल्ट वैल्यू नहीं है. |
q |
ज़रूरी
खोज स्ट्रिंग डिफ़ॉल्ट वैल्यू नहीं है. |
client_key |
खास तौर पर सुझाया गया
क्लाइंट के हिसाब से स्ट्रिंग, जो इंटिग्रेशन की जानकारी देती है. क्लाइंट कुंजी की मदद से, अलग-अलग इंटिग्रेशन में एक ही एपीआई कुंजी का इस्तेमाल किया जा सकता है. हालांकि, ऐसा करने के बाद भी उनमें अंतर किया जा सकता है. ऐप्लिकेशन इंटिग्रेशन के लिए, सभी एपीआई कॉल के लिए एक ही कोई भी क्लाइंट कस्टम व्यवहार डिफ़ॉल्ट वैल्यू नहीं है. |
country |
खास तौर पर सुझाया गया
अनुरोध करने के लिए, टारगेट किए जाने वाले देश का नाम बताएं. ऐसा करने के लिए, इसका दो अक्षरों वाला ISO 3166-1 देश कोड दें. डिफ़ॉल्ट वैल्यू |
locale |
खास तौर पर सुझाया गया
खोज स्ट्रिंग को समझने के लिए, डिफ़ॉल्ट भाषा तय करें.
डिफ़ॉल्ट वैल्यू |
limit |
ज़रूरी नहीं
तय संख्या तक नतीजे पाएं. डिफ़ॉल्ट वैल्यू |
जवाब का फ़ॉर्मैट
यहां दी गई टेबल में, Search के सुझावों वाले एंडपॉइंट के लिए, रिस्पॉन्स के फ़ॉर्मैट की जानकारी दी गई है:
सुरक्षा कुंजी | |
---|---|
results |
सुझाए गए खोज शब्दों की श्रेणी |
अनुरोध के उदाहरण
कर्ल
/* search suggestion */
curl "https://tenor.googleapis.com/v2/search_suggestions?key=API_KEY&client_key=my_test_app&q=smile&limit=5"
Python
# set the apikey and limit the # coming back
apikey = "API_KEY" # click to set to your apikey
ckey = "my_test_app" # set the client_key for the integration
lmt = 5
# partial search
search = "smile"
r = requests.get(
"https://tenor.googleapis.com/v2/search_suggestions?key=%s&client_key=%s&q=%s&limit=%s" % (apikey, ckey, search, lmt))
if r.status_code == 200:
# return the search suggestions
search_suggestion_list = json.loads(r.content)["results"]
print search_suggestion_list
else:
# handle a possible error
search_suggestion_list = []
Android/Java
import android.app.Application;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.BufferedInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.StringWriter;
import java.net.ConnectException;
import java.net.HttpURLConnection;
import java.net.URL;
public class App extends Application {
private static final String API_KEY = "API_KEY";
private static final String CLIENT_KEY = "my_test_app";
private static final String LogTag = "TenorTest";
@Override
public void onCreate() {
super.onCreate();
new Thread() {
@Override
public void run() {
// for testing, the last search
final String lastSearch = "smile";
int limit = 5;
// make the search suggestion call
JSONObject searchSuggestionResult = searchSuggestionRequest(lastSearch, limit);
// load the results for the user
Log.v(LogTag, "Search Suggestion Results: " + searchSuggestionResult.toString());
}
}.start();
}
/**
* Autocomplete Request
*/
public static JSONObject searchSuggestionRequest(String lastSearch, int limit) {
// make an autocomplete request - using default locale of EN_US
final String url = String.format("https://tenor.googleapis.com/v2/search_suggestions?key=%1$s&client_key=%2$s&q=%3$s&limit=%4$s",
API_KEY, CLIENT_KEY, lastSearch, limit);
try {
return get(url);
} catch (IOException | JSONException ignored) {
}
return null;
}
/**
* Construct and run a GET request
*/
private static JSONObject get(String url) throws IOException, JSONException {
HttpURLConnection connection = null;
try {
// Get request
connection = (HttpURLConnection) new URL(url).openConnection();
connection.setDoInput(true);
connection.setDoOutput(true);
connection.setRequestMethod("GET");
connection.setRequestProperty("Content-Type", "application/json");
connection.setRequestProperty("Accept", "application/json");
connection.setRequestProperty("Content-Type", "application/json; charset=UTF-8");
// Handle failure
int statusCode = connection.getResponseCode();
if (statusCode != HttpURLConnection.HTTP_OK && statusCode != HttpURLConnection.HTTP_CREATED) {
String error = String.format("HTTP Code: '%1$s' from '%2$s'", statusCode, url);
throw new ConnectException(error);
}
// Parse response
return parser(connection);
} catch (Exception ignored) {
} finally {
if (connection != null) {
connection.disconnect();
}
}
return new JSONObject("");
}
/**
* Parse the response into JSONObject
*/
private static JSONObject parser(HttpURLConnection connection) throws JSONException {
char[] buffer = new char[1024 * 4];
int n;
InputStream stream = null;
try {
stream = new BufferedInputStream(connection.getInputStream());
InputStreamReader reader = new InputStreamReader(stream, "UTF-8");
StringWriter writer = new StringWriter();
while (-1 != (n = reader.read(buffer))) {
writer.write(buffer, 0, n);
}
return new JSONObject(writer.toString());
} catch (IOException ignored) {
} finally {
if (stream != null) {
try {
stream.close();
} catch (IOException ignored) {
}
}
}
return new JSONObject("");
}
}
Swift 2.0+/iOS
let apikey = "API_KEY"
let clientkey = "my_test_app"
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
requestData()
return true
}
/**
Execute web requests to get search suggestions.
*/
func requestData()
{
// for testing, the partial search
let lastsearch = "smile"
let limit = 5
// Get the top 5 search suggestions - using the default locale of en_US
let suggestRequest = URLRequest(url: URL(string: String(format: "https://tenor.googleapis.com/v2/search_suggestions?key=%@&client_key=%@&q=%@&limit=%d",
apikey,
clientkey,
lastsearch,
limit))!)
makeWebRequest(urlRequest: suggestRequest, callback: tenorSuggestResultsHandler)
// Data will be loaded by each request's callback
}
/**
Async URL requesting function.
*/
func makeWebRequest(urlRequest: URLRequest, callback: @escaping ([String:AnyObject]) -> ())
{
// Make the async request and pass the resulting JSON object to the callback
let task = URLSession.shared.dataTask(with: urlRequest) { (data, response, error) in
do {
if let jsonResult = try JSONSerialization.jsonObject(with: data!, options: []) as? [String:AnyObject] {
// Push the results to our callback
callback(jsonResult)
}
} catch let error as NSError {
print(error.localizedDescription)
}
}
task.resume()
}
/**
Web response handler for search suggestion requests.
*/
func tenorSuggestResultsHandler(response: [String:AnyObject])
{
// Parse the JSON response
let searchSuggestion = response["results"]!
// Load the GIFs into your view
print("Search Suggestion Results: (searchSuggestion)")
}
}
JavaScript
<!DOCTYPE html>
<html>
<script>
// url Async requesting function
function httpGetAsync(theUrl, callback)
{
// create the request object
var xmlHttp = new XMLHttpRequest();
// set the state change callback to capture when the response comes in
xmlHttp.onreadystatechange = function()
{
if (xmlHttp.readyState == 4 && xmlHttp.status == 200)
{
callback(xmlHttp.responseText);
}
}
// open as a GET call, pass in the url and set async = True
xmlHttp.open("GET", theUrl, true);
// call send with no params as they were passed in on the url string
xmlHttp.send(null);
return;
}
// callback for share event
function tenorCallback_searchSuggestion(responsetext)
{
var response_objects = JSON.parse(responsetext);
predicted_words = response_objects["results"];
document.getElementById("ac_1").innerHTML = predicted_words[0];
document.getElementById("ac_2").innerHTML = predicted_words[1];
document.getElementById("ac_3").innerHTML = predicted_words[2];
document.getElementById("ac_4").innerHTML = predicted_words[3];
}
// SUPPORT FUNCTIONS ABOVE
// MAIN BELOW
//search term
psearch_term = "smile";
// set the apikey and limit
var apikey = "API_KEY";
var clientkey = "my_test_app";
var lmt = 5;
// using default locale of en_US
var autoc_url = "https://tenor.googleapis.com/v2/search_suggestions?key=" + apikey + "&client_key=" + clientkey + "&q=" + psearch_term + "&limit=" + lmt;
// send search suggestion request
httpGetAsync(autoc_url,tenorCallback_searchSuggestion);
</script>
<body>
<h2>Search Suggestion for "smile":</h2>
<h3 id = "ac_1"></h3>
<h3 id = "ac_2"></h3>
<h3 id = "ac_3"></h3>
<h3 id = "ac_4"></h3>
</body>
</html>
Objective-C
NSString *apiKey = @"API_KEY";
NSString *clientKey = @"my_test_app";
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
[self requestData];
return YES;
}
/**
Execute web requests to get search suggestions.
*/
-(void)requestData
{
// Define the results upper limit
int limit = 5;
// the test search term
NSString *lastSearch = @"smile";
// Get the search suggestions for the given last search - using the default locale of en_US
NSString *UrlString = [NSString stringWithFormat:@"https://tenor.googleapis.com/v2/search_suggestions?key=%@&client_key=%@&q=%@&limit=%d", apiKey, clientKey, lastSearch, limit];
NSURL *searchUrl = [NSURL URLWithString:UrlString];
NSURLRequest *searchRequest = [NSURLRequest requestWithURL:searchUrl];
[self makeWebRequest:searchRequest withCallback:tenorSearchSuggestionResultsHandler];
// Data will be loaded by each request's callback
}
/**
Async URL requesting function.
*/
-(void)makeWebRequest:(NSURLRequest *)urlRequest withCallback:(void (^)(NSDictionary *))callback
{
// Make the async request and pass the resulting JSON object to the callback
NSURLSessionTask *task = [[NSURLSession sharedSession] dataTaskWithRequest:urlRequest completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) {
NStopGifsError *jsonError = nil;
NSDictionary *jsonResult = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableLeaves error:&jsonError];
if(jsonError != nil) {
NSLog(@"%@", jsonError.localizedDescription);
return;
}
// Push the results to our callback
callback(jsonResult);
}];
[task resume];
}
/**
Web response handler for search suggestions
*/
void (^tenorSearchSuggestionResultsHandler)(NSDictionary *) = ^void(NSDictionary *response)
{
// Parse the JSON response
NSDictionary *results = response[@"results"];
// Load the GIFs into your view
NSLog(@"Search Suggestion Result: %@", results);
};
ऑटोकंप्लीट
मूल URL
https://tenor.googleapis.com/v2/autocomplete?q=<term>&key=<API KEY>
ऐसा JSON ऑब्जेक्ट पाएं जिसमें खोज के लिए इस्तेमाल हुए किसी शब्द के लिए, खोज के लिए इस्तेमाल हुए शब्दों की सूची शामिल हो. यह सूची Tenor के एआई (AI) के हिसाब से क्रम में लगी है. साथ ही, Tenor का एआई (AI) और सटीक हो जाने पर, नतीजों की संख्या कम हो जाती है.
सबसे सही तरीके
- अपने इंटिग्रेशन को अलग दिखाने के लिए, एपीआई के
key
के साथ-साथclient_key
पैरामीटर दें. - नतीजों को उपयोगकर्ता की भाषा में दिखाने के लिए,
locale
पैरामीटर का इस्तेमाल करें. डिफ़ॉल्ट वैल्यूen_US
होती है. - नतीजों को उसी क्रम में दिखाएं जिस क्रम में आपने उन्हें अपलोड किया है.
पैरामीटर में
इस टेबल में, ऑटोकंप्लीट एंडपॉइंट के पैरामीटर की जानकारी दी गई है:
पैरामीटर में | |
---|---|
key |
ज़रूरी
खास अधिकारों वाले एपीआई के ऐक्सेस के लिए एपीआई कुंजी डिफ़ॉल्ट वैल्यू नहीं है. |
q |
ज़रूरी
खोज स्ट्रिंग डिफ़ॉल्ट वैल्यू नहीं है. |
client_key |
खास तौर पर सुझाया गया
क्लाइंट के हिसाब से स्ट्रिंग, जो इंटिग्रेशन की जानकारी देती है. क्लाइंट कुंजी की मदद से, अलग-अलग इंटिग्रेशन में एक ही एपीआई कुंजी का इस्तेमाल किया जा सकता है. हालांकि, ऐसा करने के बाद भी उनमें अंतर किया जा सकता है. ऐप्लिकेशन इंटिग्रेशन के लिए, सभी एपीआई कॉल के लिए एक ही कोई भी क्लाइंट कस्टम व्यवहार डिफ़ॉल्ट वैल्यू नहीं है. |
country |
खास तौर पर सुझाया गया
अनुरोध करने के लिए, टारगेट किए जाने वाले देश का नाम बताएं. ऐसा करने के लिए, इसका दो अक्षरों वाला ISO 3166-1 देश कोड दें. डिफ़ॉल्ट वैल्यू |
locale |
खास तौर पर सुझाया गया
खोज स्ट्रिंग को समझने के लिए, डिफ़ॉल्ट भाषा तय करें.
डिफ़ॉल्ट वैल्यू |
limit |
ज़रूरी नहीं
तय संख्या तक नतीजे पाएं. डिफ़ॉल्ट वैल्यू |
जवाब का फ़ॉर्मैट
इस टेबल में, ऑटोकंप्लीट एंडपॉइंट के लिए रिस्पॉन्स फ़ॉर्मैट के बारे में जानकारी दी गई है:
सुरक्षा कुंजी | |
---|---|
results |
सुझाए गए खोज शब्दों की श्रेणी |
अनुरोध के उदाहरण
कर्ल
/* autocomplete */
curl "https://tenor.googleapis.com/v2/autocomplete?key=API_KEY&client_key=my_test_app&q=exc"
Python
apikey = "API_KEY" # click to set to your apikey
ckey = "my_test_app" # set the client_key for the integration
lmt = 5
# partial search
psearch = "exc"
r = requests.get(
"https://tenor.googleapis.com/v2/autocomplete?key=%s&client_key=%s&q=%s&limit=%s" % (apikey, ckey, psearch, lmt))
if r.status_code == 200:
# return the search predictions
search_term_list = json.loads(r.content)["results"]
print(search_term_list)
else:
# handle a possible error
search_term_list = []
Android/Java
import android.app.Application;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.BufferedInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.StringWriter;
import java.net.ConnectException;
import java.net.HttpURLConnection;
import java.net.URL;
public class App extends Application {
private static final String API_KEY = "API_KEY";
private static final String CLIENT_KEY = "my_test_app";
private static final String LogTag = "TenorTest";
@Override
public void onCreate() {
super.onCreate();
new Thread() {
@Override
public void run() {
// for testing, the partial search
final String partialSearch = "exc";
int limit = 5;
// make the autocomplete call
JSONObject autoCompleteResult = autoCompleteRequest(partialSearch, limit);
// load the results for the user
Log.v(LogTag, "AutoComplete Results: " + autoCompleteResult.toString());
}
}.start();
}
/**
* Autocomplete Request
*/
public static JSONObject autoCompleteRequest(String partialSearch, int limit) {
// make an autocomplete request - using default locale of EN_US
final String url = String.format("https://tenor.googleapis.com/v2/autocomplete?key=%1$s&client_key=%2$s&q=%3$s&limit=%4$s",
API_KEY, CLIENT_KEY, partialSearch, limit);
try {
return get(url);
} catch (IOException | JSONException ignored) {
}
return null;
}
/**
* Construct and run a GET request
*/
private static JSONObject get(String url) throws IOException, JSONException {
HttpURLConnection connection = null;
try {
// Get request
connection = (HttpURLConnection) new URL(url).openConnection();
connection.setDoInput(true);
connection.setDoOutput(true);
connection.setRequestMethod("GET");
connection.setRequestProperty("Content-Type", "application/json");
connection.setRequestProperty("Accept", "application/json");
connection.setRequestProperty("Content-Type", "application/json; charset=UTF-8");
// Handle failure
int statusCode = connection.getResponseCode();
if (statusCode != HttpURLConnection.HTTP_OK && statusCode != HttpURLConnection.HTTP_CREATED) {
String error = String.format("HTTP Code: '%1$s' from '%2$s'", statusCode, url);
throw new ConnectException(error);
}
// Parse response
return parser(connection);
} catch (Exception ignored) {
} finally {
if (connection != null) {
connection.disconnect();
}
}
return new JSONObject("");
}
/**
* Parse the response into JSONObject
*/
private static JSONObject parser(HttpURLConnection connection) throws JSONException {
char[] buffer = new char[1024 * 4];
int n;
InputStream stream = null;
try {
stream = new BufferedInputStream(connection.getInputStream());
InputStreamReader reader = new InputStreamReader(stream, "UTF-8");
StringWriter writer = new StringWriter();
while (-1 != (n = reader.read(buffer))) {
writer.write(buffer, 0, n);
}
return new JSONObject(writer.toString());
} catch (IOException ignored) {
} finally {
if (stream != null) {
try {
stream.close();
} catch (IOException ignored) {
}
}
}
return new JSONObject("");
}
}
Swift 2.0+/iOS
let apikey = "API_KEY"
let clientkey = "my_test_app"
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
requestData()
return true
}
/**
Execute web requests to get autocomplete suggestions.
*/
func requestData()
{
// for testing, the partial search
let partialSearch = "exc"
let limit = 5
// Get up to 5 results from the autocomplete suggestions - using the default locale of en_US
let autoRequest = URLRequest(url: URL(string: String(format: "https://tenor.googleapis.com/v2/autocomplete?key=%@&client_key=%@&q=%@&limit=%d",
apikey,
clientkey,
partialSearch,
limit))!)
makeWebRequest(urlRequest: autoRequest, callback: tenorAutoCompleteResultsHandler)
// Data will be loaded by each request's callback
}
/**
Async URL requesting function.
*/
func makeWebRequest(urlRequest: URLRequest, callback: @escaping ([String:AnyObject]) -> ())
{
// Make the async request and pass the resulting JSON object to the callback
let task = URLSession.shared.dataTask(with: urlRequest) { (data, response, error) in
do {
if let jsonResult = try JSONSerialization.jsonObject(with: data!, options: []) as? [String:AnyObject] {
// Push the results to our callback
callback(jsonResult)
}
} catch let error as NSError {
print(error.localizedDescription)
}
}
task.resume()
}
/**
Web response handler for autocomplete requests.
*/
func tenorAutoCompleteResultsHandler(response: [String:AnyObject])
{
// Parse the JSON response
let autoSuggestions = response["results"]!
// Load the GIFs into your view
print("Autocomplete Results: (autoSuggestions)")
}
}
JavaScript
<!DOCTYPE html>
<html>
<script>
// url Async requesting function
function httpGetAsync(theUrl, callback)
{
// create the request object
var xmlHttp = new XMLHttpRequest();
// set the state change callback to capture when the response comes in
xmlHttp.onreadystatechange = function()
{
if (xmlHttp.readyState == 4 && xmlHttp.status == 200)
{
callback(xmlHttp.responseText);
}
}
// open as a GET call, pass in the url and set async = True
xmlHttp.open("GET", theUrl, true);
// call send with no params as they were passed in on the url string
xmlHttp.send(null);
return;
}
// callback for share event
function tenorCallback_autocomplete(responsetext)
{
var response_objects = JSON.parse(responsetext);
predicted_words = response_objects["results"];
document.getElementById("ac_1").innerHTML = predicted_words[0];
document.getElementById("ac_2").innerHTML = predicted_words[1];
}
// SUPPORT FUNCTIONS ABOVE
// MAIN BELOW
//partial search term
psearch_term = "exc";
// set the apikey and limit
var apikey = "API_KEY";
var clientkey = "my_test_app";
var lmt = 5;
// using default locale of en_US
var autoc_url = "https://tenor.googleapis.com/v2/autocomplete?key=" + apikey + "&client_key=" + clientkey + "&q=" + psearch_term + "&limit=" + lmt;
// send autocomplete request
httpGetAsync(autoc_url,tenorCallback_autocomplete);
</script>
<body>
<h2>Partial Search "exc":</h2>
<h3 id = "ac_1"></h3>
<h3 id = "ac_2"></h3>
</body>
</html>
Objective-C
NSString *apiKey = @"API_KEY";
NSString *clientKey = @"my_test_app";
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
[self requestData];
return YES;
}
/**
Execute web requests to get autocomplete suggestions.
*/
-(void)requestData
{
// Define the results upper limit
int limit = 8;
// the test search term
NSString *partialSearch = @"exc";
// Get the auto complete predictions for the given partial search - using the default locale of en_US
NSString *UrlString = [NSString stringWithFormat:@"https://tenor.googleapis.com/v2/autocomplete?key=%@&client_key=%@&q=%@&limit=%d", apiKey, clientKey, partialSearch, limit];
NSURL *searchUrl = [NSURL URLWithString:UrlString];
NSURLRequest *searchRequest = [NSURLRequest requestWithURL:searchUrl];
[self makeWebRequest:searchRequest withCallback:tenorAutoCompleteResultsHandler];
// Data will be loaded by each request's callback
}
/**
Async URL requesting function.
*/
-(void)makeWebRequest:(NSURLRequest *)urlRequest withCallback:(void (^)(NSDictionary *))callback
{
// Make the async request and pass the resulting JSON object to the callback
NSURLSessionTask *task = [[NSURLSession sharedSession] dataTaskWithRequest:urlRequest completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) {
NStopGifsError *jsonError = nil;
NSDictionary *jsonResult = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableLeaves error:&jsonError];
if(jsonError != nil) {
NSLog(@"%@", jsonError.localizedDescription);
return;
}
// Push the results to our callback
callback(jsonResult);
}];
[task resume];
}
/**
Web response handler for auto complete predictions
*/
void (^tenorAutoCompleteResultsHandler)(NSDictionary *) = ^void(NSDictionary *response)
{
// Parse the JSON response
NSDictionary *results = response[@"results"];
// Load the GIFs into your view
NSLog(@"Auto Complete Result: %@", results);
};
खोज के लिए ऐसे शब्द जो रुझान में हैं
मूल URL
https://tenor.googleapis.com/v2/trending_terms?<parameters>
ऐसा JSON ऑब्जेक्ट पाएं जिसमें खोज के लिए इस्तेमाल किए जा रहे मौजूदा शब्दों की सूची मौजूद हो. Tenor का एआई (AI) हर घंटे के हिसाब से सूची को अपडेट करता है.
सबसे सही तरीके
- अपने इंटिग्रेशन को अलग दिखाने के लिए, एपीआई के
key
के साथ-साथclient_key
पैरामीटर दें. - नतीजों को उसी क्रम में दिखाएं जिस क्रम में आपने उन्हें अपलोड किया है.
पैरामीटर में
नीचे दी गई टेबल में, रुझान में चल रहे खोज के लिए शब्दों वाले एंडपॉइंट के पैरामीटर के बारे में जानकारी दी गई है:
पैरामीटर में | |
---|---|
key |
ज़रूरी
खास अधिकारों वाले एपीआई के ऐक्सेस के लिए एपीआई कुंजी डिफ़ॉल्ट वैल्यू नहीं है. |
client_key |
खास तौर पर सुझाया गया
क्लाइंट के हिसाब से स्ट्रिंग, जो इंटिग्रेशन की जानकारी देती है. क्लाइंट कुंजी की मदद से, अलग-अलग इंटिग्रेशन में एक ही एपीआई कुंजी का इस्तेमाल किया जा सकता है. हालांकि, ऐसा करने के बाद भी उनमें अंतर किया जा सकता है. ऐप्लिकेशन इंटिग्रेशन के लिए, सभी एपीआई कॉल के लिए एक ही कोई भी क्लाइंट कस्टम व्यवहार डिफ़ॉल्ट वैल्यू नहीं है. |
country |
खास तौर पर सुझाया गया
अनुरोध करने के लिए, टारगेट किए जाने वाले देश का नाम बताएं. ऐसा करने के लिए, इसका दो अक्षरों वाला ISO 3166-1 देश कोड दें. डिफ़ॉल्ट वैल्यू |
locale |
खास तौर पर सुझाया गया
खोज स्ट्रिंग को समझने के लिए, डिफ़ॉल्ट भाषा तय करें.
डिफ़ॉल्ट वैल्यू |
limit |
ज़रूरी नहीं
तय संख्या तक नतीजे पाएं. डिफ़ॉल्ट वैल्यू |
जवाब का फ़ॉर्मैट
नीचे दी गई टेबल में, चर्चा में चल रहे खोज के लिए शब्दों वाले एंडपॉइंट के रिस्पॉन्स फ़ॉर्मैट का ब्यौरा दिया गया है:
सुरक्षा कुंजी | |
---|---|
results |
सुझाए गए खोज शब्दों की श्रेणी. शब्दों को उनके ट्रेंडिंग रैंक के हिसाब से क्रम में लगाया जाता है. |
अनुरोध के उदाहरण
कर्ल
/* trending Terms call */
curl "https://tenor.googleapis.com/v2/trending_terms?key=API_KEY&client_key=my_test_app"
Python
import requests
import json
apikey = "API_KEY" # click to set to your apikey
ckey = "my_test_app" # set the client_key for the integration
# get the current list of categories - using the default locale of en_US
r = requests.get("https://tenor.googleapis.com/v2/trending_terms?key=%s&client_key=%s" % (apikey,ckey))
if r.status_code == 200:
trending_terms = json.loads(r.content)
else:
trending_terms = None
# load the results
print(trending_terms)
Android/Java
import android.app.Application;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.BufferedInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.StringWriter;
import java.net.ConnectException;
import java.net.HttpURLConnection;
import java.net.URL;
public class App extends Application {
private static final String API_KEY = "API_KEY";
private static final String CLIENT_KEY = "my_test_app";
private static final String LogTag = "TenorTest";
@Override
public void onCreate() {
super.onCreate();
new Thread() {
@Override
public void run() {
// get the current list of categories
JSONObject terms = getTrendingTerms();
// load the results for the user
Log.v(LogTag, "Trending Terms: " + terms.toString());
}
}.start();
}
/**
* Get trending terms
*/
public static JSONObject getTrendingTerms() {
// get the categories - using the default locale of en_US
final String url = String.format("https://tenor.googleapis.com/v2/trending_terms?key=%1$s&client_key=%2$s",
API_KEY, CLIENT_KEY);
try {
return get(url);
} catch (IOException | JSONException ignored) {
}
return null;
}
/**
* Construct and run a GET request
*/
private static JSONObject get(String url) throws IOException, JSONException {
HttpURLConnection connection = null;
try {
// Get request
connection = (HttpURLConnection) new URL(url).openConnection();
connection.setDoInput(true);
connection.setDoOutput(true);
connection.setRequestMethod("GET");
connection.setRequestProperty("Content-Type", "application/json");
connection.setRequestProperty("Accept", "application/json");
connection.setRequestProperty("Content-Type", "application/json; charset=UTF-8");
// Handle failure
int statusCode = connection.getResponseCode();
if (statusCode != HttpURLConnection.HTTP_OK && statusCode != HttpURLConnection.HTTP_CREATED) {
String error = String.format("HTTP Code: '%1$s' from '%2$s'", statusCode, url);
throw new ConnectException(error);
}
// Parse response
return parser(connection);
} catch (Exception ignored) {
} finally {
if (connection != null) {
connection.disconnect();
}
}
return new JSONObject("");
}
/**
* Parse the response into JSONObject
*/
private static JSONObject parser(HttpURLConnection connection) throws JSONException {
char[] buffer = new char[1024 * 4];
int n;
InputStream stream = null;
try {
stream = new BufferedInputStream(connection.getInputStream());
InputStreamReader reader = new InputStreamReader(stream, "UTF-8");
StringWriter writer = new StringWriter();
while (-1 != (n = reader.read(buffer))) {
writer.write(buffer, 0, n);
}
return new JSONObject(writer.toString());
} catch (IOException ignored) {
} finally {
if (stream != null) {
try {
stream.close();
} catch (IOException ignored) {
}
}
}
return new JSONObject("");
}
}
Swift 2.0+/iOS
let apikey = "API_KEY"
let clientkey = "my_test_app"
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
requestData()
return true
}
/**
Execute web requests to retrieve trending terms.
*/
func requestData()
{
// Get the current list of categories - using the default locale of en_US
let categoryRequest = URLRequest(url: URL(string: String(format: "https://tenor.googleapis.com/v2/trending_terms?key=%@&client_key=%@",
apikey, clientkey))!)
makeWebRequest(urlRequest: categoryRequest, callback: tenorTermsResultsHandler)
// Data will be loaded by each request's callback
}
/**
Async URL requesting function.
*/
func makeWebRequest(urlRequest: URLRequest, callback: @escaping ([String:AnyObject]) -> ())
{
// Make the async request and pass the resulting JSON object to the callback
let task = URLSession.shared.dataTask(with: urlRequest) { (data, response, error) in
do {
if let jsonResult = try JSONSerialization.jsonObject(with: data!, options: []) as? [String:AnyObject] {
// Push the results to our callback
callback(jsonResult)
}
} catch let error as NSError {
print(error.localizedDescription)
}
}
task.resume()
}
/**
Web response handler for GIF categories.
*/
func tenorTermsResultsHandler(response: [String:AnyObject])
{
// Parse the JSON response
let terms = response["results"]!
// Load the categories into your view
print("Trending Terms Results: (terms)")
}
}
JavaScript
<!DOCTYPE html>
<html>
<script>
// url Async requesting function
function httpGetAsync(theUrl, callback)
{
// create the request object
var xmlHttp = new XMLHttpRequest();
// set the state change callback to capture when the response comes in
xmlHttp.onreadystatechange = function()
{
if (xmlHttp.readyState == 4 && xmlHttp.status == 200)
{
callback(xmlHttp.responseText);
}
}
// open as a GET call, pass in the url and set async = True
xmlHttp.open("GET", theUrl, true);
// call send with no params as they were passed in on the url string
xmlHttp.send(null);
return;
}
// callback for GIF categories
function tenorCallback_terms(responsetext)
{
// Parse the JSON response
var response_objects = JSON.parse(responsetext);
terms = response_objects["results"];
document.getElementById("res").innerHTML = terms
return;
}
// function to call the trending terms
function grab_data()
{
// set the apikey and limit
var apikey = "API_KEY";
var clientkey = "my_test_app";
var lmt = 10;
// get the current list of trending terms - using the default locale of en_US
var cat_url = "https://tenor.googleapis.com/v2/trending_terms?key=" + apikey + "&client_key=" + clientkey;
httpGetAsync(cat_url,tenorCallback_terms);
// data will be loaded by each call's callback
return;
}
// SUPPORT FUNCTIONS ABOVE
// MAIN BELOW
// start the flow
grab_data();
</script>
<style>
.container {
position: relative;
text-align: center;
color: white;
}
.title {
text-align: center;
}
.centered {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
</style>
<body>
<h2 class="title">Trending Terms</h2>
<div class="container" id="res">
</div>
</body>
</html>
Objective-C
NSString *apiKey = @"API_KEY";
NSString *clientKey = @"my_test_app";
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
[self requestData];
return YES;
}
/**
Execute web requests to retrieve trending terms.
*/
-(void)requestData
{
// Get the current list of categories - using the default locale of en_US
NSString *categoryUrlString = [NSString stringWithFormat:@"https://tenor.googleapis.com/v2/trending_terms?key=%@&client_key=%@", apiKey, clientkey];
NSURL *categoryUrl = [NSURL URLWithString:categoryUrlString];
NSURLRequest *categoryRequest = [NSURLRequest requestWithURL:categoryUrl];
[self makeWebRequest:categoryRequest withCallback:tenorTermsResultsHandler];
// Data will be loaded by each request's callback
}
/**
Async URL requesting function.
*/
-(void)makeWebRequest:(NSURLRequest *)urlRequest withCallback:(void (^)(NSDictionary *))callback
{
// Make the async request and pass the resulting JSON object to the callback
NSURLSessionTask *task = [[NSURLSession sharedSession] dataTaskWithRequest:urlRequest completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) {
NSError *jsonError = nil;
NSDictionary *jsonResult = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableLeaves error:&jsonError];
if(jsonError != nil) {
NSLog(@"%@", jsonError.localizedDescription);
return;
}
// Push the results to our callback
callback(jsonResult);
}];
[task resume];
}
/**
Web response handler for GIF categories.
*/
void (^tenorTermsResultsHandler)(NSDictionary *) = ^void(NSDictionary *response)
{
// Parse the JSON response
NSDictionary *terms = response[@"results"];
// Load the categories into your view
NSLog(@"Trending Terms: %@", terms);
};
रजिस्टर शेयर
मूल URL
https://tenor.googleapis.com/v2/registershare?<parameters>
GIF या स्टिकर शेयर करने के लिए, उपयोगकर्ता को रजिस्टर करें.
सबसे सही तरीके
- अपने इंटिग्रेशन को अलग दिखाने के लिए, एपीआई के
key
के साथ-साथclient_key
पैरामीटर दें. - खोज के लिए शब्द डालें. इससे, Tenor के सर्च इंजन एआई (AI) को बेहतर बनाने में मदद मिलती है. इससे, उपयोगकर्ताओं को बेहतर GIF या स्टिकर ढूंढने में आसानी होती है.
- शेयर सिग्नल की क्षेत्रीय प्रासंगिकता बढ़ाने के लिए,
locale
पैरामीटर का इस्तेमाल करें. डिफ़ॉल्ट वैल्यूen_US
होती है.
पैरामीटर में
नीचे दी गई टेबल, रजिस्टर शेयर एंडपॉइंट के पैरामीटर के बारे में जानकारी देती है:
पैरामीटर में | |
---|---|
key |
ज़रूरी
खास अधिकारों वाले एपीआई के ऐक्सेस के लिए एपीआई कुंजी डिफ़ॉल्ट वैल्यू नहीं है. |
id |
ज़रूरी
रिस्पॉन्स ऑब्जेक्ट का डिफ़ॉल्ट वैल्यू नहीं है. |
client_key |
खास तौर पर सुझाया गया
क्लाइंट के हिसाब से स्ट्रिंग, जो इंटिग्रेशन की जानकारी देती है. क्लाइंट कुंजी की मदद से, अलग-अलग इंटिग्रेशन में एक ही एपीआई कुंजी का इस्तेमाल किया जा सकता है. हालांकि, ऐसा करने के बाद भी उनमें अंतर किया जा सकता है. ऐप्लिकेशन इंटिग्रेशन के लिए, सभी एपीआई कॉल के लिए एक ही कोई भी क्लाइंट कस्टम व्यवहार डिफ़ॉल्ट वैल्यू नहीं है. |
country |
खास तौर पर सुझाया गया
अनुरोध करने के लिए, टारगेट किए जाने वाले देश का नाम बताएं. ऐसा करने के लिए, इसका दो अक्षरों वाला ISO 3166-1 देश कोड दें. डिफ़ॉल्ट वैल्यू |
locale |
खास तौर पर सुझाया गया
खोज स्ट्रिंग को समझने के लिए, डिफ़ॉल्ट भाषा तय करें.
डिफ़ॉल्ट वैल्यू |
q |
खास तौर पर सुझाया गया
वह शेयर जो इस शेयर पर ले जाता है. डिफ़ॉल्ट वैल्यू नहीं है. |
जवाब का फ़ॉर्मैट
रजिस्टर शेयर एंडपॉइंट का कोई औपचारिक जवाब नहीं है. डेवलपर, एचटीटीपीएस रिस्पॉन्स कोड की जांच करके यह पता लगा सकते हैं कि वे एपीआई पर पहुंच गए हैं या नहीं.
अनुरोध के उदाहरण
कर्ल
/* register share */
curl "https://tenor.googleapis.com/v2/registershare?id=16989471141791455574&key=API_KEY&client_key=my_test_app&q=excited"
Python
# set the apikey
apikey = "API_KEY" # click to set to your apikey
ckey = "my_test_app" # set the client_key for the integration
# get the GIF's id and search used
shard_gifs_id = top_8gifs["results"][0]["id"]
search_term = "excited"
r = requests.get("https://tenor.googleapis.com/v2/registershare?id=%s&key=%s&client_key=%s&q=%s" % (shard_gifs_id, apikey, ckey, search_term))
if r.status_code == 200:
pass
# move on
else:
pass
# handle error
Android/Java
import android.app.Application;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.BufferedInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.StringWriter;
import java.net.ConnectException;
import java.net.HttpURLConnection;
import java.net.URL;
public class App extends Application {
private static final String API_KEY = "API_KEY";
private static final String CLIENT_KEY = "my_test_app";
private static final String LogTag = "TenorTest";
@Override
public void onCreate() {
super.onCreate();
new Thread() {
@Override
public void run() {
// test values for the share example
final String gifId = "16989471141791455574";
final String searchTerm = "excited";
// make the register share call
JSONObject shareResult = registerShare(gifId, searchTerm);
// load the results for the user
Log.v(LogTag, "Share Results: " + shareResult.toString());
}
}.start();
}
/**
* Register the GIF share
*/
public static JSONObject registerShare(String gifId, String searchTerm) {
// make register share request - using default locale of EN_US
final String url = String.format("https://tenor.googleapis.com/v2/registershare?key=%1$s&client_key=%2$s&id=%3$s&q=%4$s",
API_KEY, CLIENT_KEY, gifId, searchTerm);
try {
return get(url);
} catch (IOException | JSONException ignored) {
}
return null;
}
/**
* Construct and run a GET request
*/
private static JSONObject get(String url) throws IOException, JSONException {
HttpURLConnection connection = null;
try {
// Get request
connection = (HttpURLConnection) new URL(url).openConnection();
connection.setDoInput(true);
connection.setDoOutput(true);
connection.setRequestMethod("GET");
connection.setRequestProperty("Content-Type", "application/json");
connection.setRequestProperty("Accept", "application/json");
connection.setRequestProperty("Content-Type", "application/json; charset=UTF-8");
// Handle failure
int statusCode = connection.getResponseCode();
if (statusCode != HttpURLConnection.HTTP_OK && statusCode != HttpURLConnection.HTTP_CREATED) {
String error = String.format("HTTP Code: '%1$s' from '%2$s'", statusCode, url);
throw new ConnectException(error);
}
// Parse response
return parser(connection);
} catch (Exception ignored) {
} finally {
if (connection != null) {
connection.disconnect();
}
}
return new JSONObject("");
}
/**
* Parse the response into JSONObject
*/
private static JSONObject parser(HttpURLConnection connection) throws JSONException {
char[] buffer = new char[1024 * 4];
int n;
InputStream stream = null;
try {
stream = new BufferedInputStream(connection.getInputStream());
InputStreamReader reader = new InputStreamReader(stream, "UTF-8");
StringWriter writer = new StringWriter();
while (-1 != (n = reader.read(buffer))) {
writer.write(buffer, 0, n);
}
return new JSONObject(writer.toString());
} catch (IOException ignored) {
} finally {
if (stream != null) {
try {
stream.close();
} catch (IOException ignored) {
}
}
}
return new JSONObject("");
}
}
Swift 2.0+/iOS
let apikey = "API_KEY"
let clientkey = "my_test_app"
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
// test values for the share example
let gifId = "16989471141791455574"
let searchTerm = "excited"
// register the user's share
registerShare(gifId: gifId, searchTerm: searchTerm)
return true
}
// Function for handling a user's selection of a GIF to share.
// In a production application, the GIF id should be the "id" field of the GIF response object that the user selected
// to share. The search term should be the user's last search.
func registerShare(gifId: String, searchTerm: String) {
// Register the user's share - using the default locale of en_US
let shareRequest = URLRequest(url: URL(string: String(format: "https://tenor.googleapis.com/v2/registershare?key=%@&client_key=%@&id=%@&q=%@",
apikey,
clientkey,
gifId,
searchTerm))!)
makeWebRequest(urlRequest: shareRequest, callback: tenorShareHandler)
// Data will be loaded by each request's callback
}
/**
Async URL requesting function.
*/
func makeWebRequest(urlRequest: URLRequest, callback: @escaping ([String:AnyObject]) -> ())
{
// Make the async request and pass the resulting JSON object to the callback
let task = URLSession.shared.dataTask(with: urlRequest) { (data, response, error) in
do {
if let jsonResult = try JSONSerialization.jsonObject(with: data!, options: []) as? [String:AnyObject] {
// Push the results to our callback
callback(jsonResult)
}
} catch let error as NSError {
print(error.localizedDescription)
}
}
task.resume()
}
/**
Web response handler for search requests.
*/
func tenorShareHandler(response: [String:AnyObject])
{
// no response expected from the registershare endpoint
}
JavaScript
<!DOCTYPE html>
<html>
<script>
// url Async requesting function
function httpGetAsync(theUrl, callback)
{
// create the request object
var xmlHttp = new XMLHttpRequest();
// set the state change callback to capture when the response comes in
xmlHttp.onreadystatechange = function()
{
if (xmlHttp.readyState == 4 && xmlHttp.status == 200)
{
callback(xmlHttp.responseText);
}
}
// open as a GET call, pass in the url and set async = True
xmlHttp.open("GET", theUrl, true);
// call send with no params as they were passed in on the url string
xmlHttp.send(null);
return;
}
// callback for share event
function tenorCallback_share(responsetext)
{
// no action is needed in the share callback
}
// function to call the register share endpoint
function send_share(search_term,shared_gifs_id)
{
// set the apikey and limit
var apikey = "API_KEY";
var clientkey = "my_test_app";
var share_url = "https://tenor.googleapis.com/v2/registershare?id=" + shared_gifs_id + "&key=" + apikey + "&client_key=" + clientkey + "&q=" + search_term;
httpGetAsync(share_url,tenorCallback_share);
}
// SUPPORT FUNCTIONS ABOVE
// MAIN BELOW
// grab search term from cookies or some other storage
search_term = "excited";
// GIF id from the shared gif
// shared_gifs_id = gif_json_response_object_from_search["results"][0]["id"]
shared_gifs_id = "16989471141791455574"; // example
// send the share notifcation back to Tenor
send_share(search_term,shared_gifs_id);
alert("share sent!");
</script>
<body>
</body>
</html>
Objective-C
NSString *apiKey = @"API_KEY";
NSString *clientKey = @"my_test_app";
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
[self requestData];
return YES;
}
/**
Function for handling a user's selection of a GIF to share.
In a production application, the GIF id should be the "id" field of the GIF response object that the user selected
to share. The search term should be the user's last search.
*/
-(void)requestData
{
// the test search term
NSString *searchQuery = @"excited";
NSString *gifId = @"16989471141791455574";
// Send the share event for the GIF id and search query
NSString *UrlString = [NSString stringWithFormat:@"https://tenor.googleapis.com/v2/registershare?id=%@&key=%@&client_key=%@&q=%@", gifId, apiKey, clientKey, searchQuery];
NSURL *searchUrl = [NSURL URLWithString:UrlString];
NSURLRequest *searchRequest = [NSURLRequest requestWithURL:searchUrl];
[self makeWebRequest:searchRequest withCallback:tenorSearchResultsHandler];
// Data will be loaded by each request's callback
}
/**
Async URL requesting function.
*/
-(void)makeWebRequest:(NSURLRequest *)urlRequest withCallback:(void (^)(NSDictionary *))callback
{
// Make the async request and pass the resulting JSON object to the callback
NSURLSessionTask *task = [[NSURLSession sharedSession] dataTaskWithRequest:urlRequest completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) {
NStopGifsError *jsonError = nil;
NSDictionary *jsonResult = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableLeaves error:&jsonError];
if(jsonError != nil) {
NSLog(@"%@", jsonError.localizedDescription);
return;
}
// Push the results to our callback
callback(jsonResult);
}];
[task resume];
}
/**
Web response handler for registered shares
*/
void (^tenorShareResultsHandler)(NSDictionary *) = ^void(NSDictionary *response)
{
// no response expected from the registershare endpoint.
};
पोस्ट
मूल URL
https://tenor.googleapis.com/v2/posts?<parameters>
बताए गए आईडी के लिए GIF, स्टिकर या दोनों का कॉम्बिनेशन पाएं.
सबसे सही तरीके
- अपने इंटिग्रेशन को अलग दिखाने के लिए, एपीआई के
key
के साथ-साथclient_key
पैरामीटर दें. - GIF फ़ॉर्मैट की संख्या कम करने के लिए,
media_filter
पैरामीटर का इस्तेमाल करें. इससे, रिस्पॉन्स ऑब्जेक्ट का साइज़ 75% कम हो सकता है.
पैरामीटर में
इस टेबल में, पोस्ट एंडपॉइंट के पैरामीटर की जानकारी दी गई है:
पैरामीटर में | |
---|---|
key |
ज़रूरी
खास अधिकारों वाले एपीआई के ऐक्सेस के लिए एपीआई कुंजी डिफ़ॉल्ट वैल्यू नहीं है. |
ids |
ज़रूरी
रिस्पॉन्स ऑब्जेक्ट आईडी की कॉमा-सेपरेटेड लिस्ट. कोई डिफ़ॉल्ट वैल्यू नहीं है और ज़्यादा से ज़्यादा वैल्यू |
client_key |
खास तौर पर सुझाया गया
क्लाइंट के हिसाब से स्ट्रिंग, जो इंटिग्रेशन की जानकारी देती है. क्लाइंट कुंजी की मदद से, अलग-अलग इंटिग्रेशन में एक ही एपीआई कुंजी का इस्तेमाल किया जा सकता है. हालांकि, ऐसा करने के बाद भी उनमें अंतर किया जा सकता है. ऐप्लिकेशन इंटिग्रेशन के लिए, सभी एपीआई कॉल के लिए एक ही क्लाइंट का कोई भी कस्टम व्यवहार, डिफ़ॉल्ट वैल्यू नहीं है. |
media_filter |
खास तौर पर सुझाया गया
रिस्पॉन्स ऑब्जेक्ट को फ़िल्टर करने के लिए, GIF फ़ॉर्मैट की कॉमा-सेपरेटेड लिस्ट. डिफ़ॉल्ट रूप से, उदाहरण: डिफ़ॉल्ट वैल्यू नहीं है. |
जवाब का फ़ॉर्मैट
इस टेबल में, पोस्ट एंडपॉइंट के रिस्पॉन्स फ़ॉर्मैट के बारे में जानकारी दी गई है:
सुरक्षा कुंजी | |
---|---|
results |
रिस्पॉन्स ऑब्जेक्ट की कैटगरी, जो |
अनुरोध के उदाहरण
कर्ल
/* Posts endpoint */
curl "https://tenor.googleapis.com/v2/posts?key=API_KEY&client_key=my_test_app&ids=11586094175715197775"
Python
apikey = "API_KEY" # click to set to your apikey
ckey = "my_test_app" # set the client_key for the integration
# our gif id
gifid = "11586094175715197775"
# get the specific gif
r = requests.get(
"https://tenor.googleapis.com/v2/posts?ids=%s&key=%s&client_key=%s" % (gifid, apikey,ckey))
if r.status_code == 200:
# load the GIFs using the urls for the smaller GIF sizes
gifs = json.loads(r.content)
print(gifs)
else:
gifs = None
Android/Java
import android.app.Application;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.BufferedInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.StringWriter;
import java.net.ConnectException;
import java.net.HttpURLConnection;
import java.net.URL;
public class App extends Application {
private static final String API_KEY = "API_KEY";
private static final String CLIENT_KEY = "my_test_app";
private static final String LogTag = "TenorTest";
@Override
public void onCreate() {
super.onCreate();
new Thread() {
@Override
public void run() {
final String gif_id ="11586094175715197775";
// get the requested gif
JSONObject gifResult = getGifResults(gif_id);
// load the results for the user
Log.v(LogTag, "Gif Results: " + gifResult.toString());
}
}.start();
}
/**
* Get Search Result GIFs
*/
public static JSONObject getGifResults(String gif_id) {
final String url = String.format("https://tenor.googleapis.com/v2/posts?ids=%1$s&key=%2$s&client_key=%3$s",
gif_id, API_KEY, CLIENT_KEY);
try {
return get(url);
} catch (IOException | JSONException ignored) {
}
return null;
}
/**
* Construct and run a GET request
*/
private static JSONObject get(String url) throws IOException, JSONException {
HttpURLConnection connection = null;
try {
// Get request
connection = (HttpURLConnection) new URL(url).openConnection();
connection.setDoInput(true);
connection.setDoOutput(true);
connection.setRequestMethod("GET");
connection.setRequestProperty("Content-Type", "application/json");
connection.setRequestProperty("Accept", "application/json");
connection.setRequestProperty("Content-Type", "application/json; charset=UTF-8");
// Handle failure
int statusCode = connection.getResponseCode();
if (statusCode != HttpURLConnection.HTTP_OK && statusCode != HttpURLConnection.HTTP_CREATED) {
String error = String.format("HTTP Code: '%1$s' from '%2$s'", statusCode, url);
throw new ConnectException(error);
}
// Parse response
return parser(connection);
} catch (Exception ignored) {
} finally {
if (connection != null) {
connection.disconnect();
}
}
return new JSONObject("");
}
/**
* Parse the response into JSONObject
*/
private static JSONObject parser(HttpURLConnection connection) throws JSONException {
char[] buffer = new char[1024 * 4];
int n;
InputStream stream = null;
try {
stream = new BufferedInputStream(connection.getInputStream());
InputStreamReader reader = new InputStreamReader(stream, "UTF-8");
StringWriter writer = new StringWriter();
while (-1 != (n = reader.read(buffer))) {
writer.write(buffer, 0, n);
}
return new JSONObject(writer.toString());
} catch (IOException ignored) {
} finally {
if (stream != null) {
try {
stream.close();
} catch (IOException ignored) {
}
}
}
return new JSONObject("");
}
}
Swift 2.0+/iOS
let apikey = "API_KEY"
let clientkey = "my_test_app"
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
requestData()
return true
}
/**
Execute web request to the requested gif.
*/
func requestData()
{
// the test gif id
let gifid = "11586094175715197775"
// request the gif
let searchRequest = URLRequest(url: URL(string: String(format: "https://tenor.googleapis.com/v2/posts?ids=%@&key=%@&client_key=%@",
gifid,
apikey,
clientkey))!)
makeWebRequest(urlRequest: searchRequest, callback: tenorgifHandler)
// Data will be loaded by each request's callback
}
/**
Async URL requesting function.
*/
func makeWebRequest(urlRequest: URLRequest, callback: @escaping ([String:AnyObject]) -> ())
{
// Make the async request and pass the resulting JSON object to the callback
let task = URLSession.shared.dataTask(with: urlRequest) { (data, response, error) in
do {
if let jsonResult = try JSONSerialization.jsonObject(with: data!, options: []) as? [String:AnyObject] {
// Push the results to our callback
callback(jsonResult)
}
} catch let error as NSError {
print(error.localizedDescription)
}
}
task.resume()
}
/**
Web response handler for search requests.
*/
func tenorgifHandler(response: [String:AnyObject])
{
// Parse the JSON response
let responseGifs = response["results"]!
// Load the GIFs into your view
print("Result GIFS: (responseGifs)")
}
}
JavaScript
<!DOCTYPE html>
<html>
<script>
// url Async requesting function
function httpGetAsync(theUrl, callback)
{
// create the request object
var xmlHttp = new XMLHttpRequest();
// set the state change callback to capture when the response comes in
xmlHttp.onreadystatechange = function()
{
if (xmlHttp.readyState == 4 && xmlHttp.status == 200)
{
callback(xmlHttp.responseText);
}
}
// open as a GET call, pass in the url and set async = True
xmlHttp.open("GET", theUrl, true);
// call send with no params as they were passed in on the url string
xmlHttp.send(null);
return;
}
// callback for the requested gif
function tenorCallback_gifs(responsetext)
{
// Parse the JSON response
var response_objects = JSON.parse(responsetext);
var gif = response_objects["results"];
// load the GIFs -- for our example we will load the first GIFs preview size (nanogif) and share size (gif)
document.getElementById("preview_gif").src = gif[0]["media_formats"]["nanogif"]["url"];
document.getElementById("share_gif").src = gif[0]["media_formats"]["gif"]["url"];
return;
}
// function to call the trending and category endpoints
function grab_data()
{
// set the apikey and limit
var apikey = "API_KEY";
var clientkey = "my_test_app";
// GIF id
var gif_id = "11586094175715197775";
// using default locale of en_US
var search_url = "https://tenor.googleapis.com/v2/posts?ids=" + gif_id + "&key=" +
apikey + "&client_key=" + clientkey;
httpGetAsync(search_url,tenorCallback_gifs);
// data will be loaded by each call's callback
return;
}
// SUPPORT FUNCTIONS ABOVE
// MAIN BELOW
// start the flow
grab_data();
</script>
<body>
<h2># 1 GIF loaded - preview image</h2>
<img id="preview_gif" src="" alt="" style="width:220px;height:164px;">
<h2># 1 GIF loaded - share image</h2>
<img id="share_gif" src="" alt="" style="width:498px;height:372px;">
</body>
</html>
Objective-C
NSString *apiKey = @"API_KEY";
NSString *clientKey = @"my_test_app";
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
[self requestData];
return YES;
}
/**
Execute web request to retrieve the requested gif.
*/
-(void)requestData
{
NSString *gifid = @"11586094175715197775";
// Get the GIF
NSString *UrlString = [NSString stringWithFormat:@"https://tenor.googleapis.com/v2/posts?key=%@&client_key=%@&ids=%@", apiKey, clientKey, gifid];
NSURL *searchUrl = [NSURL URLWithString:UrlString];
NSURLRequest *searchRequest = [NSURLRequest requestWithURL:searchUrl];
[self makeWebRequest:searchRequest withCallback:tenorgifResultsHandler];
// Data will be loaded by each request's callback
}
/**
Async URL requesting function.
*/
-(void)makeWebRequest:(NSURLRequest *)urlRequest withCallback:(void (^)(NSDictionary *))callback
{
// Make the async request and pass the resulting JSON object to the callback
NSURLSessionTask *task = [[NSURLSession sharedSession] dataTaskWithRequest:urlRequest completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) {
NStopGifsError *jsonError = nil;
NSDictionary *jsonResult = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableLeaves error:&jsonError];
if(jsonError != nil) {
NSLog(@"%@", jsonError.localizedDescription);
return;
}
// Push the results to our callback
callback(jsonResult);
}];
[task resume];
}
/**
Web response handler for searches.
*/
void (^tenorgifResultsHandler)(NSDictionary *) = ^void(NSDictionary *response)
{
// Parse the JSON response
NSDictionary *gif = response[@"results"];
// Load the GIFs into your view
NSLog(@"GIF Results: %@", gif);
};