我想縮短使用谷歌縮短api的網址,我試過我的運氣找到谷歌上的東西可以幫助我,但我沒有發現任何博客或在java/android的東西可以幫助我。如果有人有更好的資源,請給我建議。這裏是我的代碼如何使用谷歌縮短api創建縮短的網址
public class tinyurl extends Activity implements OnClickListener {
EditText original;
TextView txt;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
Button btn = (Button) findViewById(R.id.Button01);
original = (EditText) findViewById(R.id.edittext);
txt = (TextView) findViewById(R.id.TextView03);
btn.setOnClickListener(this);
}
@Override
public void onClick(View v) {
final String GOOGL_URL = "https://www.googleapis.com/urlshortener/v1/url?key=AIzaSyAau1E_WrYwMiTNqhK5hgH0tyWudyahbOI";
String tinyUrl = null;
String original = "http://www.google.com/";
HttpTransport transport = GoogleTransport.create();
GoogleHeaders defaultHeaders = new GoogleHeaders();
transport.defaultHeaders = defaultHeaders;
transport.defaultHeaders.put("Content-Type", "application/json");
transport.addParser(new JsonHttpParser());
HttpRequest request = transport.buildPostRequest();
request.setUrl(GOOGL_URL);
GenericData data = new GenericData();
// data.put("longUrl", "http://www.google.com/");
data.put("longUrl", original);
JsonHttpContent content = new JsonHttpContent();
content.data = data;
request.content = content;
HttpResponse response = null;
try {
response = request.execute();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
Log.d("eception occured", e.toString());
}
Result result = null;
try {
result = response.parseAs(Result.class);
Log.d("TinyUrl", result.shortUrl.toString());
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public class Result extends GenericJson {
public String shortUrl;
}
}
所有我面臨強制關閉,由於這一行的時間。
response = request.execute();
有什麼建議嗎?
這是我的堆棧跟蹤,如果它提供任何幫助。
05-12 23:48:55.033: ERROR/AndroidRuntime(455): FATAL EXCEPTION: main
05-12 23:48:55.033: ERROR/AndroidRuntime(455): java.lang.ExceptionInInitializerError
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at com.google.api.client.json.JsonHttpContent.writeTo(JsonHttpContent.java:66)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at com.google.api.client.apache.ContentEntity.writeTo(ContentEntity.java:55)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at org.apache.http.impl.entity.EntitySerializer.serialize(EntitySerializer.java:97)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at org.apache.http.impl.AbstractHttpClientConnection.sendRequestEntity(AbstractHttpClientConnection.java:161)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at org.apache.http.impl.conn.AbstractClientConnAdapter.sendRequestEntity(AbstractClientConnAdapter.java:272)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at org.apache.http.protocol.HttpRequestExecutor.doSendRequest(HttpRequestExecutor.java:237)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at org.apache.http.protocol.HttpRequestExecutor.execute(HttpRequestExecutor.java:119)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:410)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at com.google.api.client.apache.ApacheHttpRequest.execute(ApacheHttpRequest.java:47)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at com.google.api.client.http.HttpRequest.execute(HttpRequest.java:207)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at com.tinyurl.tinyurl.onClick(tinyurl.java:113)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at android.view.View.performClick(View.java:2408)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at android.view.View$PerformClick.run(View.java:8816)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at android.os.Handler.handleCallback(Handler.java:587)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at android.os.Handler.dispatchMessage(Handler.java:92)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at android.os.Looper.loop(Looper.java:123)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at android.app.ActivityThread.main(ActivityThread.java:4627)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at java.lang.reflect.Method.invokeNative(Native Method)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at java.lang.reflect.Method.invoke(Method.java:521)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at dalvik.system.NativeStart.main(Native Method)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): Caused by: java.lang.NoClassDefFoundError: org.codehaus.jackson.JsonFactory
05-12 23:48:55.033: ERROR/AndroidRuntime(455): at com.google.api.client.json.Json.<clinit>(Json.java:56)
05-12 23:48:55.033: ERROR/AndroidRuntime(455): ... 25 more
粘貼到您的堆棧跟蹤在這裏,你有沒有上網的權限在您的清單? – FoamyGuy 2011-05-12 21:34:42
是的,我在我的清單中有互聯網許可。 – PiyushMishra 2011-05-12 21:37:45