Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/419.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 使用Java通过Accesstoken从Linkedin获取数据_Javascript_Java_Oauth_Linkedin_Scribe - Fatal编程技术网

Javascript 使用Java通过Accesstoken从Linkedin获取数据

Javascript 使用Java通过Accesstoken从Linkedin获取数据,javascript,java,oauth,linkedin,scribe,Javascript,Java,Oauth,Linkedin,Scribe,我已经从linkedin OAuth弹出窗口中获得了身份验证令牌(我不知道它是访问令牌还是授权代码)。下面是获取身份验证令牌的代码 <script type="text/javascript" src="//platform.linkedin.com/in.js"> api_key:77ok0qpcsnr6z9 </script> <script type="text/javascript"> /*globa

我已经从linkedin OAuth弹出窗口中获得了身份验证令牌(我不知道它是访问令牌还是授权代码)。下面是获取身份验证令牌的代码

 <script type="text/javascript" src="//platform.linkedin.com/in.js">
        api_key:77ok0qpcsnr6z9
     </script>
    <script type="text/javascript">
        /*global IN*/
        IN.Event.on(IN, "systemReady", sysRed);
        function callbackFunction() {
            debugger;
            alert("oAuth Token: " +IN.ENV.auth.oauth_token);
        }
        function sysRed(){
            alert('system is ready');
            IN.User.authorize(callbackFunction);
        }
    </script>
下面是代码

package com.linkedin.data;

import java.util.Scanner;

import com.github.scribejava.apis.LinkedInApi20;
import com.github.scribejava.core.builder.ServiceBuilder;
import com.github.scribejava.core.model.OAuthRequest;
import com.github.scribejava.core.model.Response;
import com.github.scribejava.core.model.Token;
import com.github.scribejava.core.model.Verb;
import com.github.scribejava.core.model.Verifier;
import com.github.scribejava.core.oauth.OAuth20ServiceImpl;

public class GetLinkedInData {

    private static final String NETWORK_NAME = "LinkedIn";
    private static final String PROTECTED_RESOURCE_URL = "https://api.linkedin.com/v1/people/~:(%s)";
    private static final Token EMPTY_TOKEN = null;

    public static void main(String[] args) {
        // Replace these with your client id and secret
        final String clientId = "secretclinetid";
        final String clientSecret = "secretcodefromapi";
        final OAuth20ServiceImpl service = (OAuth20ServiceImpl) new ServiceBuilder()
                .provider(LinkedInApi20.class).apiKey(clientId)
                .apiSecret(clientSecret)
                .scope("r_fullprofile,r_emailaddress,r_contactinfo")
                // replace with desired scope
                .callback("http://localhost:8888/linkednOauth.html").state("some_params")
                .build();
        Scanner in = new Scanner(System.in);

        System.out.println("=== " + NETWORK_NAME + "'s OAuth Workflow ===");
        System.out.println();

        // Obtain the Authorization URL
        System.out.println("Fetching the Authorization URL...");
        final String authorizationUrl = service
                .getAuthorizationUrl(EMPTY_TOKEN);
        System.out.println("Got the Authorization URL!");
        System.out.println("Now go and authorize ScribeJava here:");
        System.out.println(authorizationUrl);
        System.out.println("And paste the authorization code here");
        System.out.print(">>");
        Verifier verifier = new Verifier(oAuthcodefroLinkedinPopup);
        System.out.println();

        // Trade the Request Token and Verfier for the Access Token
        System.out.println("Trading the Request Token for an Access Token...");
        Token accessToken = service.getAccessToken(EMPTY_TOKEN, verifier);
        System.out.println("Got the Access Token!");
        System.out.println("(if your curious it looks like this: "
                + accessToken + " )");
        System.out.println();

        // Now let's go and ask for a protected resource!
        System.out.println("Now we're going to access a protected resource...");
        while (true) {
            System.out.println("Paste profile query for fetch");
            System.out.print(">>");
            final String query = in.nextLine();
            System.out.println();

            final OAuthRequest request = new OAuthRequest(Verb.GET,
                    String.format(PROTECTED_RESOURCE_URL, query), service);
            request.addHeader("x-li-format", "json");
            request.addHeader("Accept-Language", "ru-RU");
            service.signRequest(accessToken, request);
            final Response response = request.send();
            System.out.println();
            System.out.println(response.getCode());
            System.out.println(response.getBody());

            System.out.println();
        }
    }
}

和这个有关吗@DeividiCavarzan感谢链接,但即使在我添加了标题之后,也没有用。还是一样。
package com.linkedin.data;

import java.util.Scanner;

import com.github.scribejava.apis.LinkedInApi20;
import com.github.scribejava.core.builder.ServiceBuilder;
import com.github.scribejava.core.model.OAuthRequest;
import com.github.scribejava.core.model.Response;
import com.github.scribejava.core.model.Token;
import com.github.scribejava.core.model.Verb;
import com.github.scribejava.core.model.Verifier;
import com.github.scribejava.core.oauth.OAuth20ServiceImpl;

public class GetLinkedInData {

    private static final String NETWORK_NAME = "LinkedIn";
    private static final String PROTECTED_RESOURCE_URL = "https://api.linkedin.com/v1/people/~:(%s)";
    private static final Token EMPTY_TOKEN = null;

    public static void main(String[] args) {
        // Replace these with your client id and secret
        final String clientId = "secretclinetid";
        final String clientSecret = "secretcodefromapi";
        final OAuth20ServiceImpl service = (OAuth20ServiceImpl) new ServiceBuilder()
                .provider(LinkedInApi20.class).apiKey(clientId)
                .apiSecret(clientSecret)
                .scope("r_fullprofile,r_emailaddress,r_contactinfo")
                // replace with desired scope
                .callback("http://localhost:8888/linkednOauth.html").state("some_params")
                .build();
        Scanner in = new Scanner(System.in);

        System.out.println("=== " + NETWORK_NAME + "'s OAuth Workflow ===");
        System.out.println();

        // Obtain the Authorization URL
        System.out.println("Fetching the Authorization URL...");
        final String authorizationUrl = service
                .getAuthorizationUrl(EMPTY_TOKEN);
        System.out.println("Got the Authorization URL!");
        System.out.println("Now go and authorize ScribeJava here:");
        System.out.println(authorizationUrl);
        System.out.println("And paste the authorization code here");
        System.out.print(">>");
        Verifier verifier = new Verifier(oAuthcodefroLinkedinPopup);
        System.out.println();

        // Trade the Request Token and Verfier for the Access Token
        System.out.println("Trading the Request Token for an Access Token...");
        Token accessToken = service.getAccessToken(EMPTY_TOKEN, verifier);
        System.out.println("Got the Access Token!");
        System.out.println("(if your curious it looks like this: "
                + accessToken + " )");
        System.out.println();

        // Now let's go and ask for a protected resource!
        System.out.println("Now we're going to access a protected resource...");
        while (true) {
            System.out.println("Paste profile query for fetch");
            System.out.print(">>");
            final String query = in.nextLine();
            System.out.println();

            final OAuthRequest request = new OAuthRequest(Verb.GET,
                    String.format(PROTECTED_RESOURCE_URL, query), service);
            request.addHeader("x-li-format", "json");
            request.addHeader("Accept-Language", "ru-RU");
            service.signRequest(accessToken, request);
            final Response response = request.send();
            System.out.println();
            System.out.println(response.getCode());
            System.out.println(response.getBody());

            System.out.println();
        }
    }
}