❶ 新浪微博中的android sdk中的example如何测试
1、SDK example本身就是一个工程,导入到Eclipse中就好了,注意会有一个错误。修改好直接就可以运行测试了。通过OAuth认证登录,显示微博列表。
2、网络中搜“ppy2790博客”中有新浪微博开发系列文章。很详细。
❷ 引入新浪微博SDK的weibo4android怎么不能用,求高手
feeeeeeeeeeee
❸ 新浪微博API授权问题:回拨地址如何填写
可以在高阶应用资讯里面修改域名系结 Host下修改127.0.0.1指向你的回拨域名
设定成引数,每次字串查加就可以了
你把你登入后的资讯储存到一个SharedPreferences中。然后就可以呼叫判断了,没有登入的话就让他跳到授权页面,这样例子,本社群就有几个,你找找看。。。。
新浪的SDK里有
$o = new WeiboOAuth( WB_AKEY , WB_SKEY );
$keys = $o- > getRequestToken();
$aurl = $o- > getAuthorizeURL( $keys['oauth_token'] ,false , $_SERVER['SCRIPT_URI'].'/callback.php');
你好朋友这情况应当是你登入360的网站或360安全卫士,建议你退出后就会显示不线上了。
请问您的手机是什么机型呢?您可以进入i管家--软体管理--软体许可权管理中找到新浪微博并开启相应的许可权的。
下载一直播后使用新浪微博登陆即可,或者再已经注册的一直播app内系结新浪微博。
下载官方的SDK,在里面有例项和MD5的签名工具。
官方SDK
在里面的签名工具,根据你输入的包名来得到MD5值,你需要这个值来正确的建立应用。
在里面的还有weiboSDK,你需要把它加入你的应用中,引用其中的方法。
在清单中加入访问网路的许可权
需要在新浪的开放平台建立应用。
建立应用吧!
定义授权引数的接口:
(老实说,我是直接的demo,改为自己的授权资讯就可以了)。
[] view plainprint?
public interface Constants {
/** 当前 DEMO 应用的 APP_KEY,第三方应用应该使用自己的 APP_KEY 替换该 APP_KEY */
public static final String APP_KEY = "1608434710";
public static final String REDIRECT_URL = ":sina.";
public static final String SCOPE =
"email,direct_messages_read,direct_messages_write,"
+ "friendships_groups_read,friendships_groups_write,statuses_to_me_read,"
+ "follow_app_official_microblog," + "invitation_write";
}
快取授权资讯:
[] view plainprint?
/**
* 该类定义了微博授权时所需要的引数。
*/
public class AessTokenKeeper {
private static final String PREFERENCES_NAME = "_weibo_sdk_android";
private static final String KEY_UID = "uid";
private static final String KEY_ACCESS_TOKEN = "aess_token";
private static final String KEY_EXPIRES_IN = "expires_in";
/**
* 储存 Token 物件到 SharedPreferences。
*
* @param context 应用程式上下文环境
* @param token Token 物件
*/
public static void writeAessToken(Context context, Oauth2AessToken token) {
if (null == context || null == token) {
return;
}
SharedPreferences pref = context.getSharedPreferences(PREFERENCES_NAME, Context.MODE_APPEND);
Editor editor = pref.edit();
editor.putString(KEY_UID, token.getUid());
editor.putString(KEY_ACCESS_TOKEN, token.getToken());
editor.putLong(KEY_EXPIRES_IN, token.getExpiresTime());
editor.mit();
}
/**
* 从 SharedPreferences 读取 Token 资讯。
*
* @param context 应用程式上下文环境
*
* @return 返回 Token 物件
*/
public static Oauth2AessToken readAessToken(Context context) {
if (null == context) {
return null;
}
Oauth2AessToken token = new Oauth2AessToken();
SharedPreferences pref = context.getSharedPreferences(PREFERENCES_NAME, Context.MODE_APPEND);
token.setUid(pref.getString(KEY_UID, ""));
token.setToken(pref.getString(KEY_ACCESS_TOKEN, ""));
token.setExpiresTime(pref.getLong(KEY_EXPIRES_IN, 0));
return token;
}
/**
* 清空 SharedPreferences 中 Token资讯。
*
* @param context 应用程式上下文环境
*/
public static void clear(Context context) {
if (null == context) {
return;
}
SharedPreferences pref = context.getSharedPreferences(PREFERENCES_NAME, Context.MODE_APPEND);
Editor editor = pref.edit();
editor.clear();
editor.mit();
}
}
整合的sso授权 +获取使用者名称:
[] view plainprint?
/**
* 该类主要演示如何进行授权、SSO登陆。
*/
public class WBAuthActivity extends Activity implements OnClickListener {
/** 显示认证后的资讯,如 AessToken */
private TextView mTokenText;
/** 微博 Web 授权类,提供登陆等功能 */
private WeiboAuth mWeiboAuth;
/** 封装了 "aess_token","expires_in","refresh_token",并提供了他们的管理功能 */
private Oauth2AessToken mAessToken;
/** 注意:SsoHandler 仅当 SDK 支援 SSO 时有效 */
private SsoHandler mSsoHandler;
/** 使用者资讯接口 */
private UsersAPI mUsersAPI;
private Button ssoBtn;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.acy_sinasso);
initView();
}
public void initView() {
mTokenText = (TextView) findViewById(R.id.tv_txt);
SSO 授权
ssoBtn = (Button) findViewById(R.id.btn_sso);
建立微博例项
mWeiboAuth = new WeiboAuth(this, Constants.APP_KEY,
Constants.REDIRECT_URL, Constants.SCOPE);
从 SharedPreferences 中读取上次已储存好 AessToken 等资讯,
第一次启动本应用,AessToken 不可用
mAessToken = AessTokenKeeper.readAessToken(this);
if (mAessToken.isSessionValid()) {
updateTokenView(true);
}
ssoBtn.setOnClickListener(this);
}
/**
* 当 SSO 授权 Activity 退出时,该函式被呼叫。
*/
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
SSO 授权回拨
重要:发起 SSO 登陆的 Activity 必须重写 onActivityResult
if (mSsoHandler != null) {
mSsoHandler.authorizeCallBack(requestCode, resultCode, data);
}
}
/**
* 微博认证授权回拨类。 1. SSO 授权时,需要在 {@link #onActivityResult} 中呼叫
* {@link SsoHandler#authorizeCallBack} 后, 该回调才会被执行。 2. 非 SSO
* 授权时,当授权结束后,该回调就会被执行。 当授权成功后,请储存该 aess_token、expires_in、uid 等资讯到
* SharedPreferences 中。
*/
class AuthListener implements WeiboAuthListener {
授权完成
@Override
public void onComplete(Bundle values) {
从 Bundle 中解析 Token
mAessToken = Oauth2AessToken.parseAessToken(values);
if (mAessToken.isSessionValid()) {
显示 Token
updateTokenView(false);
储存 Token 到 SharedPreferences
AessTokenKeeper.writeAessToken(WBAuthActivity.this,
mAessToken);
Toast.makeText(WBAuthActivity.this, "suess!!",
Toast.LENGTH_SHORT).show();
根据uid 获取使用者的暱称,因为uid是在回拨方法从服务器传递过来的资料中。
long uid = Long.parseLong(mAessToken.getUid());
mUsersAPI.show(uid, mListener);
} else {
以下几种情况,您会收到 Code:
1. 当您未在平台上注册的应用程式的包名与签名时;
2. 当您注册的应用程式包名与签名不正确时;
3. 当您在平台上注册的包名和签名与您当前测试的应用的包名和签名不匹配时。
Toast.makeText(WBAuthActivity.this, "fail", Toast.LENGTH_LONG)
.show();
}
}
取消授权
@Override
public void onCancel() {
Toast.makeText(WBAuthActivity.this, "cancel", Toast.LENGTH_LONG)
.show();
}
授权异常
@Override
public void onWeiboException(WeiboException e) {
Toast.makeText(WBAuthActivity.this,
"Auth exception : " + e.getMessage(), Toast.LENGTH_LONG)
.show();
}
}
/**
* 显示当前 Token 资讯。 配置档案中是否已存在 token 资讯并且合法
*/
public void updateTokenView(boolean hasExisted) {
获取使用者资讯接口
mUsersAPI = new UsersAPI(mAessToken);
String date = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss")
.format(new java.util.Date(mAessToken.getExpiresTime()));
String format = getString(R.string.weibosdk_demo_token_to_string_format_1);
mTokenText
.setText(String.format(format, mAessToken.getToken(), date));
String message = String.format(format, mAessToken.getToken(), date);
if (hasExisted) {
message = getString(R.string.weibosdk_demo_token_has_existed)
+ "
" + message;
根据uid 获取使用者的暱称,因为uid是在回拨方法从服务器传递过来的资料中。
long uid = Long.parseLong(mAessToken.getUid());
mUsersAPI.show(uid, mListener);
}
mTokenText.setText(message);
}
/**
* 微博 OpenAPI 回拨接口。
*/
private RequestListener mListener = new RequestListener() {
@Override
public void onComplete(String response) {
if (!TextUtils.isEmpty(response)) {
呼叫 User#parse 将JSON串解析成User物件
User user = User.parse(response);
if (user != null) {
Toast.makeText(WBAuthActivity.this,
"获取User资讯成功,使用者暱称:" + user.screen_name,
Toast.LENGTH_LONG).show();
mTokenText.setText(user.screen_name);
} else {
Toast.makeText(WBAuthActivity.this, response,
Toast.LENGTH_LONG).show();
}
}
}
@Override
public void onWeiboException(WeiboException e) {
ErrorInfo info = ErrorInfo.parse(e.getMessage());
Toast.makeText(WBAuthActivity.this, info.toString(),
Toast.LENGTH_LONG).show();
}
};
@Override
public void onClick(View v) {
TODO Auto-generated method stub
if (v == ssoBtn) {
mSsoHandler = new SsoHandler(WBAuthActivity.this, mWeiboAuth);
mSsoHandler.authorize(new AuthListener());
}
}
}
布局:
[] view plainprint?
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android=":schemas.android./apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<.sina.weibo.sdk.widget.LoginButton
android:id="@+id/btn_sso"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp" />
<TextView
android:id="@+id/tv_txt"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="info" />
</LinearLayout>
4.当然,想使用这个功能,首先得有本地客户端,否则的话,会使用web的授权方式,慢慢的输入账户和密码来获取授权。
使新浪微博支援SSO授权有以下步骤:
新增URL scheme,在你的工程设定项,targets 一栏下,选中自己的 target,在 Info->URL Types 中新增 URL Schemes,此值是 sso 登入时回拨时所用。如果使用的是Xcode3或更低版本,则需要在plist档案中新增。如果你使用我们预设的新浪微博账号的话,将url scheme修改为“sinaweibosso.126663232”,否则是“sinaweibosso.你的新浪微博appkey”。
在你的`AppDelegate`档案里面`#import "UMSocialSnsService.h"`并实现下面的方法:
``` - (BOOL)application:(UIApplication *)application
openURL:(NSURL *)url
sourceApplication:(NSString *)sourceApplication
annotation:(id)annotation
{ 如果你除了使用我们sdk之外还要处理另外的url,你可以把`handleOpenURL:wxApiDelegate:`的实现复制到你的程式码里面,再新增你要处理的url。
return [UMSocialSnsService handleOpenURL:url wxApiDelegate:nil]; }
如果是2.1.3 以上版本:
新增URL scheme,在你的工程设定项,targets 一栏下,选中自己的 target,在 Info->URL Types 中新增 URL Schemes,此值是 sso 登入时回拨时所用。如果使用的是Xcode3或更低版本,则需要在plist档案中新增。将url scheme修改为“sina.你的友盟appkey”。
demo中没有#import "UMSocialSnsService.h"档案,单击#import "UMSocial.h"即可。
需要系结安全域名为whalecloud.,检查一下授权回拨页是不是填写了,修改为:sns.whalecloud./sina2/callback就可以。
新增URL scheme,在你的工程设定项,targets 一栏下,选中自己的 target,在 Info->URL Types 中新增 URL Schemes,此值是 sso 登入时回拨时所用。如果使用的是Xcode3或更低版本,则需要在plist档案中新增。如果你使用我们预设的新浪微博账号的话,将url scheme修改为“sinaweibosso.126663232”,否则是“sinaweibosso.你的新浪微博appkey”
在你的`AppDelegate`档案里面`#import "UMSocialSnsService.h"`并实现下面的方法:
- (BOOL)application:(UIApplication *)application
openURL:(NSURL *)url
sourceApplication:(NSString *)sourceApplication
annotation:(id)annotation
{
如果你除了使用我们sdk之外还要处理另外的url,你可以把`handleOpenURL:wxApiDelegate:`的实现复制到你的程式码里面,再新增你要处理的url。
return [UMSocialSnsService handleOpenURL:url wxApiDelegate:nil];
}
❹ 求解答新浪微博api报错
原因分析:
sdk版本不符,文件内所写的版本过低。
导入的jar包是双份sdk高版本出现这个问题。官方Demo不用导入weibo.sdk.android.sso.jar这个包。在工程weibo.sdk.android.sso.demo中已经包含了weibo.sdk.android.sso.jar的源代码。
默认编码格式与文件格式不符。
demo里有个apiBtn代码多余。
❺ android如何实现新浪微博评论,只需要实现这一个功能就行,怎么调用API和使用SDK
新浪有开放的开发者包啊···看看 具体的还真忘了
❻ 为什么在android中调用新浪微博接口发表的gif图片不动
查看微博android版sdk中发布图片的代码你会发现他是把图片转成bitmap了,而gif转bitmap只会是第一帧图片,这就是原因。解决方法是,修改这部分代码,对文件名做一个判断,如果是.gif的,就不转成bitmap,直接用文件流发布
❼ android 怎么修改第三方jar包
一、下载jd-gui.exe反编译工具。
二、用jd-gui.exe打开你的第三方jar包,这边以新浪微博sdk(weibo_sdk.jar)为例说明,打开weibo_sdk.jar
三、修改WeiboDialog文件中的内容,如上图一样选中WeiboDialog,然后点击file--》save source--》保存到桌面产生WeiboDialog.java文件
四、用记事本或source Insight 打开进行修改,修改完后保存。
五、新建一个工程,并且新建一个与WeiboDialog文件所在package一致的package,然后把WeiboDialog.java文件拷贝到新建的package中
六、若 WeiboDialog.java 拷贝进去有错误,则先修复错误,然后clean一下工程(工具栏 project --》clean)
七、找到工程所在目录中的bin\classes\....,会生成你修改后的文件的.class文件,复制到你的第三方jar所在目录。
八、用WinRAR打开你的第三方jar,替换jar中相同的该文件,ok完成!
❽ 详细讲解新浪微博的API到底如何使用
但是新浪提供的API可谓是项目繁琐,尤其是关于java的API。三个版本的javaAPI让你蛋碎到极致:weibo4j-oauth2.0,weibo4jandroid,android-sdk这三个版本真是要逆天。自从新浪微博将v1变到v2的时候,weibo4jandroid已经无法使用了,所以只能使用剩下的两个。但是当你很辛苦的下载了 版本的时候,运行这个程序,发现只能获取code,而不能获取accesstoken,打开源代码,点击里面的MainActivity,发现一句操蛋到要割掉自己小鸡鸡的话: 不要担心,通过code变成token的方法新浪其实已经提供了,只不过没有在android-sdk中间,而是在weibo4j中的 weibo4j.examples.oauth2.OAuth4Code里面:
❾ 利用新浪微博开放平台提供的sdk开发自己的android客户端问题
adroid 自带的sdk是1.5的,sina自带的几个jar包放到android项目中了吗,如果放进去了,你可以去下载缺少的jar包,导进去就可以了