java微博开发_Java使用新浪微博API开发微博应用的基本方法

这篇文章主要介绍了Java使用新浪微博API开发微博应用的基本方法,文中还给出了一个不使用任何SDK实现Oauth授权并实现简单的发布微博功能的实现方法,需要的朋友可以参考下

新浪微博API现在运用比较广泛,做一个完整的开发流程Demo

1、第一步注册,就不多说了,注册帐号以及成为开发者帐号,这步操作不会的话请你马上砸掉电脑拔掉网线回家种田。

2、第二步创建应用,开发者帐号创建好了,打开新浪微博开发平台: http://open.weibo.com

上面菜单栏点击最后一个 管理中心

49ba948fcaf13ed7ae198c1027e22dfc.png

如果是web的应用的话选择创建网站接入的应用,然后根据新浪微博的要求balabalabala自己去搞定

应用创建完毕。点击应用跳转页面,点击查看应用参数,可以看到应用的相关参数,这些参数将会在第四步用到。

3、第三步下载sdk,回到顶部的菜单栏,点击 文档 ,再点击左边菜单栏sdk,选择java sdk,然后balabala下载,这步操作有问题也请回家种田。

3b743b9d3e63a16d96e17368e9e47486.png

所谓的sdk并非是sdk(个人觉得名称有点误导),而是一个可运行的工程,下载完毕之后解压 ,并导入到eclipse,可以看到两个目录 src和example

src是新浪微博的部分

example是实例,接口的demo

4、第四步配置参数,找到src目录下的config.properties

前三个参数需要自己配置 为第二步里说过的应用参数里的参数

后面的都是默认的不需要改

前三个参数配置如下

client_ID为App Key

client_SERCRET为App Secret

redirect_URI为 OAuth2.0授权的回调URL 应用信息>高级信息>OAuth2.0 授权设置下面的授权回调页  这是一个你自己填写的URL 指向的是你自己服务器 当然在开发阶段我们可以使用任何URL 只要能够让我们了解OAuth授权的流程就好了 这里我们就输入一个http://www.baidu.com  取消授权回调页也是如此 注意这里的URL的字符串必须是一致

5、第五步获取AccessToken,正常情况下AccessToken的获取是需要通过OAuth2.0认证的,但是为了更简单我先说一种简单的方法。后面再讲OAuth2.0

还是选择最上面的菜单栏 文档>API>API测试工具

选择创建的应用 点击获取AccessToken 下面的文本框里就是我们要的AccessToken

93bc917b4d38efb3281fbd99abdd341f.png

6、第六步先做一个接口实例

去微博API里随便找一个已有权限的接口,

我随便找了一个 获取用户发布的微博  statuses/user_timeline 做测试用的

522b6b8876978276a3b16e966f2c8f32.png

点击这个接口查看这个接口详情,可以查看到接口的每个传入参数以及返回参数 这个无需多说。

不使用任何SDK实现Oauth授权并实现简单的发布微博功能:创建一个Java项目,编写如下代码,具体过程代码中已写的很清楚,这里不再做解释:

注意先修改应用ID、应用密码和回调页面成你自己的!访问授权页面:

package com;

import java.io.BufferedReader;

import java.io.InputStreamReader;

import java.io.OutputStreamWriter;

import java.net.URL;

import java.net.URLConnection;

import java.security.cert.CertificateException;

import java.security.cert.X509Certificate;

import java.util.Scanner;

import javax.net.ssl.X509TrustManager;

/**

* @author 刘显安

* 不使用任何SDK实现新浪微博Oauth授权并实现发微薄小Demo

* 日期:2012年11月11日

*/

public class Test

{

static String clientId="2355065950";//你的应用ID

static String clientSecret="72037e76bee00315691d9c30dd8a386a";//你的应用密码

static String redirectUri="https://api.weibo.com/oauth2/default.html";//你在应用管理中心设置的回调页面

public static void main(String[] args) throws Exception

{

testHttps();//测试

//第一步:访问授权页面获取授权

System.out.println("请打开你的浏览器,访问以下页面,登录你的微博账号并授权:");

System.out.println("https://api.weibo.com/oauth2/authorize?client_id="+clientId+"&response_type=code&redirect_uri="+redirectUri+"&forcelogin=true");

//第二步:获取AccessToken

System.out.println("请将授权成功后的页面地址栏中的参数code:");

String code=new Scanner(System.in).next();

getAccessToken(code);

//第三步:发布一条微博

System.out.println("请输入上面返回的值中accessToken的值:");

String accessToken=new Scanner(System.in).next();

updateStatus("发布微博测试!来自WeiboDemo!", accessToken);

}

/**

* 测试能否正常访问HTTPS打头的网站,

*/

public static void testHttps()

{

try

{

trustAllHttpsCertificates();//设置信任所有的http证书

URL url=new URL("https://api.weibo.com/oauth2/default.html");

URLConnection con=url.openConnection();

con.getInputStream();

System.out.println("恭喜,访问HTTPS打头的网站正常!");

}

catch (Exception e)

{

e.printStackTrace();

}

}

/**

* 以Post方式访问一个URL

* @param url 要访问的URL

* @param parameters URL后面“?”后面跟着的参数

*/

public static void postUrl(String url,String parameters)

{

try

{

trustAllHttpsCertificates();//设置信任所有的http证书

URLConnection conn = new URL(url).openConnection();

conn.setDoOutput(true);// 这里是关键,表示我们要向链接里注入的参数

OutputStreamWriter out = new OutputStreamWriter(conn.getOutputStream());// 获得连接输出流

out.write(parameters);

out.flush();

out.close();

// 到这里已经完成了,开始打印返回的HTML代码

BufferedReader reader = new BufferedReader(new InputStreamReader(conn.getInputStream()));

String line = null;

while ((line = reader.readLine()) != null)

{

System.out.println(line);

}

}

catch (Exception e)

{

e.printStackTrace();

}

}

/**

* 获取AccessToken

* @param code 在授权页面返回的Code

*/

public static void getAccessToken(String code)

{

String url="https://api.weibo.com/oauth2/access_token";

String parameters="client_id=" +clientId+"&client_secret=" +clientSecret+

"&grant_type=authorization_code" +"&redirect_uri=" +redirectUri+"&code="+code;

postUrl(url, parameters);

}

/**

* 利用刚获取的AccessToken发布一条微博

* @param text 要发布的微博内容

* @param accessToken 刚获取的AccessToken

*/

public static void updateStatus(String text,String accessToken)

{

String url="https://api.weibo.com/2/statuses/update.json";

String parameters="status="+text+"&access_token="+accessToken;

postUrl(url, parameters);

System.out.println("发布微博成功!");

}

/**

* 设置信任所有的http证书(正常情况下访问https打头的网站会出现证书不信任相关错误,所以必须在访问前调用此方法)

* @throws Exception

*/

private static void trustAllHttpsCertificates() throws Exception

{

javax.net.ssl.TrustManager[] trustAllCerts = new javax.net.ssl.TrustManager[1];

trustAllCerts[0] = new X509TrustManager()

{

@Override

public X509Certificate[] getAcceptedIssuers()

{

return null;

}

@Override

public void checkServerTrusted(X509Certificate[] arg0, String arg1)

throws CertificateException

{}

@Override

public void checkClientTrusted(X509Certificate[] arg0, String arg1)

throws CertificateException

{}

};

javax.net.ssl.SSLContext sc = javax.net.ssl.SSLContext.getInstance("SSL");

sc.init(null, trustAllCerts, null);

javax.net.ssl.HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());

}

}

访问授权页面:

a11455c91f167c6dc5e57ebf8111ac49.png

授权成功:

ac50547a19a62314016e939dd6cd2490.png

发布微博成功:

feac0e88fcd19956914a4c8e2d91e738.png

控制台输出结果:

08ac1a856e62e41f550fae650886b639.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我会为你解答关于 Java JMX 开发实例的问题。 JMX(Java Management Extensions)是Java平台的管理和监控系统。它提供了一种标准的方式来监视和管理Java应用程序。在Java中,可以使用JMX API来实现JMX功能。 下面是一个简单的示例,演示如何使用Java内置的API开发JMX功能: 首先,我们需要定义一个MBean接口。MBean是一个管理Bean,它是一个Java对象,用于管理和监视应用程序。以下是一个简单的MBean接口示例: ``` public interface HelloWorldMBean { public void sayHello(); public String getName(); public void setName(String name); } ``` 接下来,我们需要实现这个接口。以下是一个示例实现: ``` public class HelloWorld implements HelloWorldMBean { private String name; public void sayHello() { System.out.println("Hello " + name); } public String getName() { return name; } public void setName(String name) { this.name = name; } } ``` 现在,我们需要将这个MBean注册到MBean服务器中。以下是一个示例: ``` MBeanServer mbs = ManagementFactory.getPlatformMBeanServer(); ObjectName name = new ObjectName("com.example:type=HelloWorld"); HelloWorld mbean = new HelloWorld(); mbs.registerMBean(mbean, name); ``` 现在,我们可以使用JConsole或其他JMX客户端工具连接到应用程序,并监视和管理应用程序。我们可以使用以下命令行启动JConsole: ``` jconsole ``` 然后选择我们的应用程序并连接到它。现在,我们可以调用sayHello方法并设置name属性: ``` HelloWorldMBean mbean = JMX.newMBeanProxy(mbs, name, HelloWorldMBean.class); mbean.sayHello(); mbean.setName("World"); ``` 这就是一个简单的Java JMX开发示例。希望能对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值