アスタリスク インターフェイス用のアプリケーションを作成しようとしています。再確認したとおり、構成のセットアップは適切に行われています。
Asterisk サーバーから Config ファイルにアクセスできない理由は、接続に関係しているようです。ログイン セッションの同じインスタンスに接続するために Cookie を使用する必要があります。
しかし、これまでのところ、Cookie を適切に使用できません。少し助けが必要です。
ボタン 1 (bt1) を押してログインし、ボタン 2 (btn2) を押して構成ファイルを取得することになっています。
public class AsteriskInterface extends Activity {
private static final String TAG = " AsteriskInterface";
EditText ed1;
Button bt1,bt2;
static String url ="http://ajax.googleapis.com/ajax/services/search/web?v=1.0&q=";
static String logincmd ="http://192.168.8.2:8088/asterisk/rawman?action=login&username=admin&secret=admin123";
static String getfilecmd = "http://192.168.8.2:8088/asterisk/rawman?action=getconfig&filename=sip.conf";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
ed1 = (EditText) this.findViewById(R.id.editText);
bt1 = (Button) this.findViewById(R.id.submit);
bt2 = (Button) this.findViewById(R.id.config);
final WebView myWebView = (WebView) findViewById(R.id.webView);
bt1.setOnClickListener(new OnClickListener() {
public void onClick(View view) {
try{
new Execute().execute(logincmd);
} catch(Exception e) {
Log.v("Exception execute", "Exception:"+e.getMessage());
}
}
});
bt2.setOnClickListener(new OnClickListener() {
public void onClick(View view) {
try{
new Execute().execute(getfilecmd);
} catch(Exception e) {
Log.v("Exception execute", "Exception:"+e.getMessage());
}
//myWebView.loadUrl(cmd2);
}
});
}
public static void Response(String result) {
Log.e(TAG,result);
}
}
class Execute extends AsyncTask<String, Integer, String> {
List<String> cookies = null;
protected String doInBackground(String... searchKey) {
String cmd = searchKey[0];
try {
return action2(cmd);
} catch(Exception e) {
Log.v("Exception execute do back ground", "Exception:"+e.getMessage());
return "";
}
}
protected void onPostExecute(String result) {
try {
AsteriskInterface.Response(result);
} catch(Exception e) {
Log.v("Exception excecute onPost Execute",
"Exception:"+e.getMessage());
}
}
private String action2(String uRL) throws MalformedURLException, IOException {
StringBuilder response = new StringBuilder();
Log.v("Execute","execute url:"+uRL);
URL url = new URL(uRL);
HttpURLConnection httpconn = (HttpURLConnection) url.openConnection();
DataOutputStream out;
DataInputStream in;
if(cookies==null){
httpconn.getHeaderField("Set-Cookie");
}
if(cookies!=null){
for(String cookie : cookies){
httpconn.setRequestProperty("Cookie", cookie);
}
}
httpconn.setDoOutput(true);
String post = "mobile_app="+URLEncoder.encode("1","UTF-8");
out = new DataOutputStream(httpconn.getOutputStream());
out.writeBytes(post);
out.flush();
out.close();
in = new DataInputStream(httpconn.getInputStream());
String line = "";
String data = "";
while((line=in.readLine())!=null){
data+=line;
}
if(httpconn.getResponseCode()==HttpURLConnection.HTTP_OK) {
BufferedReader input = new BufferedReader(
new InputStreamReader(httpconn.getInputStream()),
8192);
String strLine = null;
while ((strLine = input.readLine()) != null) {
response.append(strLine);
}
input.close();
}
return response.toString();
}
}
以前のログイン セッションに接続していることがわかります。しかし、新しいコマンドを発行するにはどうすればよいでしょうか。
03-28 10:02:15.861: V/Execute(4261): 実行 URL: http://192.168.8.x:8088/asterisk/rawman?action=login&username=admin&secret=admin123 03-28 10:02:18.871 : V/Exception execute do background(4261): Exception: 接続済み 03-28 10:02:23.651: V/Execute(4261): execute url: http://192.168.8.x:8088/asterisk/rawman ?action=getconfig&filename=sip.conf 03-28 10:02:26.691: V/Exception execute do back Ground(4261): 例外: 接続済み 03-28 10:02:26.721: D/dalvikvm(4261): GC_CONCURRENT 解放226K、8% フリー 7430K/8007K、一時停止 24ms+3ms、合計 61ms