我正在尝试从Android应用程序调用Asmx(.net Web服务)。但是当我提供数据时它给出了错误:
AndroidRuntime(591): FATAL EXCEPTION: Thread-75
AndroidRuntime(591): java.lang.NullPointerException: println needs a message
在logcat中显示数据:
D\Req value1(540): NetPositionReport{arg0=64396; b=Om$@!#@M^#R; }
可能是什么问题?
MainActivity.java
package com.example.clientnetpositionreport;
import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
public class MainActivity extends Activity {
EditText e1;
Button b1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
b1=(Button) findViewById(R.id.btn);
b1.setOnClickListener(new OnClickListener(){
public void onClick(View v){
e1=(EditText)findViewById(R.id.evofclientcode);
Intent i=new Intent(MainActivity.this,GetReport.class);
i.putExtra("ClientCode",e1.getText().toString());
startActivity(i);
}
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
}
GetReport.java
package com.example.clientnetpositionreport;
import org.ksoap2.SoapEnvelope;
import org.ksoap2.serialization.PropertyInfo;
import org.ksoap2.serialization.SoapObject;
import org.ksoap2.serialization.SoapSerializationEnvelope;
import org.ksoap2.transport.HttpTransportSE;
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;
import android.widget.TextView;
public class GetReport extends Activity{
private static final String NAMESPACE ="http://xxxxxxx
private static final String URL = "http://xxxxxxxxxxxx/services/xxxx.asmx";
private static final String METHOD_NAME = "xxxxxxx";
private static final String SOAP_ACTION = "http://xxxx/xxxxxxxxx";
private String webResponse = "";
private Handler handler = new Handler();
private Thread thread;
private TextView textView1;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(1);
setContentView(R.layout.activity_tv);
textView1 = (TextView) findViewById(R.id.textview1);
//int val=getIntent().getExtras().getInt("Title");
String title= getIntent().getExtras().getString("ClientCode");
//Log.d("Data is", val);
System.out.println("Data is "+title);
startWebAccess(title);
}
public void startWebAccess(String a){
final String aa=a;
thread = new Thread(){
public void run(){
try{
Log.d("Req value0R", "Starting...");//log.d is used for debug
SoapObject request = new SoapObject(NAMESPACE, METHOD_NAME);
//simple object access protocol
PropertyInfo fromProp =new PropertyInfo();
fromProp.setName("arg0");
fromProp.setValue(aa);
fromProp.setType(String.class);
request.addProperty(fromProp);
PropertyInfo fromProp2 =new PropertyInfo();
fromProp2.setName("b");
fromProp2.setValue("Om$@!#@M^#R");
fromProp2.setType(String.class);
request.addProperty(fromProp2);
Log.d("Req value1", request.toString());
SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(SoapEnvelope.VER11);
envelope.dotNet = false;
envelope.setOutputSoapObject(request);
Log.d("Req value2", envelope.toString());
HttpTransportSE androidHttpTransport = new HttpTransportSE(URL);
System.out.println("problem1");
androidHttpTransport.debug = true;
System.out.println("problem2");
Log.d("Req value2B", androidHttpTransport.toString());
System.out.println("problem3");
androidHttpTransport.call(SOAP_ACTION, envelope);
System.out.println("problem4");
Log.d("Req value2C", androidHttpTransport.toString());
System.out.println("problem5");
Object objectResult = (Object)envelope.getResponse();
System.out.println("problem6");
webResponse = objectResult.toString();
System.out.println("problem7");
}
catch(Exception e){
System.out.println("problem8");
Log.d("Req value4", e.getMessage() );
webResponse = "Connection/Internet problem";
webResponse = "Connection/Internet problem";
// Toast.makeText(getApplicationContext(), "Loading problem/Server down", Toast.LENGTH_SHORT).show();
}
handler.post(createUI);
}
};
thread.start();
}
final Runnable createUI = new Runnable() {
public void run(){
if(webResponse!=null) {
textView1.setText(webResponse);
}
else {
webResponse ="No data provided presently";
textView1.setText(webResponse);
}
}
};
}
注意:控制台输出直到 problem6 。这意味着价值 Null (我的想法。)。请记住这一点。
activity_main.xml中
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity" >
<TextView
android:id="@+id/tvofclientcode"
android:layout_width="100dp"
android:layout_height="30dp"
android:text="Client Code"
/>
<EditText
android:id="@+id/evofclientcode"
android:layout_width="100dp"
android:layout_height="50dp"
android:layout_toRightOf="@+id/tvofclientcode"
android:inputType="text"/>
<Button
android:id="@+id/btn"
android:layout_width="100dp"
android:layout_height="40dp"
android:layout_below="@+id/tvofclientcode"
android:text="Submit"/>
</RelativeLayout>
可能是什么问题?
注意: log.d方法正在获取字符串值,因此这不是某些相关案例中的问题。
答案 0 :(得分:6)
读完你的代码后,我发现了许多小错误..
我不能在这里写下所有的错误,所以只需将你的代码与我的代码进行比较,并理解你的错误。
This is your Asmx Web-Service.
在这里你必须传递两个输入参数
<ClientCode>string</ClientCode>
<key>string</key>
但你传递的一切都错了..
您的错误代码
PropertyInfo fromProp =new PropertyInfo();
fromProp.setName("arg0");
fromProp.setValue(aa);
fromProp.setType(String.class);
request.addProperty(fromProp);
PropertyInfo fromProp2 =new PropertyInfo();
fromProp2.setName("b");
fromProp2.setValue("Om$@!#@M^#R");
fromProp2.setType(String.class);
request.addProperty(fromProp2);
你必须像这样传递
SoapObject request = new SoapObject(NAMESPACE, METHOD_NAME);
// simple object access protocol
request.addProperty("ClientCode", aa);
request.addProperty("key", "Om$@!#@M^#R");
GetReport.Class的工作代码
package com.example.clientnetpositionreport;
import org.ksoap2.SoapEnvelope;
import org.ksoap2.serialization.SoapObject;
import org.ksoap2.serialization.SoapSerializationEnvelope;
import org.ksoap2.transport.HttpTransportSE;
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;
import android.widget.TextView;
public class GetReport extends Activity {
private static final String NAMESPACE = "http://tempuri.org/"; // com.service.ServiceImpl
private static final String URL = "http://commodities.karvy.com/services/NetPositionReport.asmx";
private static final String METHOD_NAME = "NetPositionReport";
private static final String SOAP_ACTION = "http://tempuri.org/NetPositionReport";
private String webResponse = "";
private Handler handler = new Handler();
private Thread thread;
private TextView textView1;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(1);
setContentView(R.layout.fragment_item_detail);
textView1 = (TextView) findViewById(R.id.item_detail);
String title= getIntent().getExtras().getString("ClientCode");
System.out.println("Data is " + title);
startWebAccess(title);
}
public void startWebAccess(String a) {
final String aa = a;
thread = new Thread() {
public void run() {
try {
Log.d("Req value0R", "Starting...");
SoapObject request = new SoapObject(NAMESPACE, METHOD_NAME);
// simple object access protocol
request.addProperty("ClientCode", aa);
request.addProperty("key", "Om$@!#@M^#R");
Log.d("Req value1", request.toString());
HttpTransportSE androidHttpTransport = new HttpTransportSE(URL);
SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(SoapEnvelope.VER12);
envelope.dotNet = true;
envelope.bodyOut = request;
// envelope.dotNet = true;
envelope.setOutputSoapObject(request);
Log.d("Req value2", envelope.toString());
androidHttpTransport.debug = true;
androidHttpTransport.call(SOAP_ACTION, envelope);
SoapObject resultData = (SoapObject) envelope.getResponse();
if (resultData != null)
webResponse = resultData.toString();
else
webResponse = "No Data found.";
System.out.println("webResponse : " + webResponse);
}
catch (Exception e) {
e.printStackTrace();
webResponse = "Connection/Internet problem";
}
handler.post(createUI);
}
};
thread.start();
}
final Runnable createUI = new Runnable() {
public void run() {
if (webResponse != null) {
textView1.setText(webResponse);
} else {
webResponse = "No data provided presently";
textView1.setText(webResponse);
}
}
};
}
这是代码正在运行,但我没有得到回应可能是我传递的错误值 ClientCode 和键
答案 1 :(得分:2)
@ xxeemez-ashu:
我得到回复,用以下代码更改你的GetReport.java
public class GetReport extends Activity {
private static final String NAMESPACE = "http://tempuri.org/"; // com.service.ServiceImpl
private static final String URL = "http://commodities.karvy.com/services/NetPositionReport.asmx";
private static final String METHOD_NAME = "NetPositionReport";
private static final String SOAP_ACTION = "http://tempuri.org/NetPositionReport";
private String webResponse = "";
private Handler handler = new Handler();
private Thread thread;
private TextView textView1;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(1);
setContentView(R.layout.activity_tv);
textView1 = (TextView) findViewById(R.id.textView1);
String title = getIntent().getExtras().getString("ClientCode");
startWebAccess(title);
}
public void startWebAccess(String a) {
final String aa = a;
thread = new Thread() {
public void run() {
try {
Log.d("Req value0R", "Starting...");// log.d is used for
// debug
SoapObject request = new SoapObject(NAMESPACE, METHOD_NAME);
request.addProperty("ClientCode", "64396");
request.addProperty("key", "Om$@!#@M^#R");
Log.d("Req value1", request.toString());
SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(
SoapEnvelope.VER11);
envelope.dotNet = true;
envelope.setOutputSoapObject(request);
HttpTransportSE androidHttpTransport = new HttpTransportSE(
URL);
androidHttpTransport.debug = true;
androidHttpTransport.call(SOAP_ACTION, envelope);
SoapObject objectResult = (SoapObject) envelope.bodyIn;
webResponse = objectResult.toString();
System.out.println("response: " + webResponse);
} catch (SoapFault sp) {
sp.getMessage();
System.out.println("error = " + sp.getMessage());
} catch (Exception e) {
System.out.println("problem8");
e.printStackTrace();
webResponse = "Connection/Internet problem";
}
handler.post(createUI);
}
};
thread.start();
}
final Runnable createUI = new Runnable() {
public void run() {
if (webResponse != null) {
textView1.setText(webResponse);
} else {
webResponse = "No data provided presently";
textView1.setText(webResponse);
}
}
};
}
保存更改并运行应用程序并查看logcat,您将获得数据并享受...
如果有任何问题,请告诉我,如果工作正常,请选择我的答案......
答案 2 :(得分:1)
尝试使用我的课程
package com.example.xmlparser;
import org.ksoap2.SoapEnvelope;
import org.ksoap2.SoapFault;
import org.ksoap2.serialization.SoapObject;
import org.ksoap2.serialization.SoapSerializationEnvelope;
import org.ksoap2.transport.HttpTransportSE;
import android.util.Log;
import com.example.helpers.Helper;
public class SoapParser {
private static final String TAG = "SaopParser";
public String call(String name) {
String returnString = "";
SoapObject request = new SoapObject(Helper.TARGET_NAMESPACE,
Helper.OPERATION_NAME);
Log.i(TAG, "Getting Name :: " + name);
// request.addProperty("Celsius", txtCel.getText().toString());
request.addProperty("companyName", name);
// PropertyInfo info = new PropertyInfo();
//
// info.setType(PropertyInfo.STRING_CLASS);
// info.setName("companyName");
// info.setValue(name);
//
// request.addProperty(info);
SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(
SoapEnvelope.VER11);
envelope.dotNet = true;
envelope.setOutputSoapObject(request);
try {
HttpTransportSE transportSE = new HttpTransportSE(
Helper.SOAP_ADDRESS);
transportSE.call(Helper.SOAP_ACTION, envelope);
returnString = envelope.getResponse().toString();
Log.i(TAG, envelope.getResponse().toString());
} catch (SoapFault e) {
e.printStackTrace();
Log.i(TAG, "Getting Exception");
} catch (Exception e) {
e.printStackTrace();
}
return returnString;
}
}
Helper.TARGET_NAMESPACE是名称空间
Helper.OPERATION_NAME是mwthod name
答案 3 :(得分:0)
我会评论,但我没有做过代表。
我会尝试替换
Object objectResult = (Object)envelope.getResponse();
与
SoapObject objectResult = (SoapObject)envelope.getResponse();
另外我注意到你指向的网络服务是.aspx,但你有 envelope.dotNet = false; //你不想把它改成真的吗?