- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
您好,我对 Android 开发非常陌生。我在使用 JSP 连接 Android 与 MySQL 数据库时遇到问题。我读了很多文档,但我不知道如何解决这个问题。我不确定,但我认为问题与空指针问题有关。但我不知道它在哪里......
这是我的java代码。
主Activity.java
package com.example.user.nacho_http_connection_test;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.os.StrictMode;
import android.util.Log;
import android.view.View;
import android.widget.EditText;
import android.widget.Toast;
import com.google.android.gms.appindexing.AppIndex;
import com.google.android.gms.common.api.GoogleApiClient;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.BufferedReader;
import java.io.InputStreamReader;
public class MainActivity extends Activity {
EditText edit_id, edit_pw;
/**
* ATTENTION: This was auto-generated to implement the App Indexing API.
* See https://g.co/AppIndexing/AndroidStudio for more information.
*/
private GoogleApiClient client;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
edit_id = (EditText) findViewById(R.id.login_id);
edit_pw = (EditText) findViewById(R.id.login_pw);
// ATTENTION: This was auto-generated to implement the App Indexing API.
// See https://g.co/AppIndexing/AndroidStudio for more information.
client = new GoogleApiClient.Builder(this).addApi(AppIndex.API).build();
}
public void join_btn(View view) {
Intent intent;
intent = new Intent(this, LoginActivity.class);
startActivity(intent);
finish();
}
public void login_btn(View view) {
StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
StrictMode.setThreadPolicy(policy);
String sMessage = edit_id.getText().toString();
String result = SendByHttp(sMessage);
String[][] parsedData = jsonParserList(result);
if (parsedData[0][0].equals("succed")) {
Toast.makeText(MainActivity.this, "Login Success", Toast.LENGTH_LONG).show();
Intent intent = new Intent(this, LoginActivity.class);
startActivity(intent);
finish();
}
}
private String SendByHttp(String msg) {
if (msg == null) {
msg = "";
}
String URL = "http://IP address/Test_Json/User.jsp";
DefaultHttpClient client = new DefaultHttpClient();
try {
HttpPost post = new HttpPost(URL + "?id=" + edit_id.getText().toString()+"&pw="+edit_pw.getText().toString());
HttpResponse response = client.execute(post);
BufferedReader bufreader = new BufferedReader(new InputStreamReader(response.getEntity().getContent(), "utf-8"));
String line = null;
String result = "";
while ((line = bufreader.readLine()) != null) {
result += line;
}
return result;
} catch (Exception e) {
e.printStackTrace();
client.getConnectionManager().shutdown();
return "";
}
}
public String[][] jsonParserList(String pRecvServerPage){
Log.i("whole content from Server", pRecvServerPage);
try{
JSONObject json = new JSONObject(pRecvServerPage);
JSONArray jArr = json.getJSONArray("List");
String[] jsonName = {"msg1","msg2","msg3"};
String[][] parseredData = new String[jArr.length()][jsonName.length];
for(int i = 0; i<jArr.length();i++){
json = jArr.getJSONObject(i);
for (int j=0;j<jsonName.length; j++){
parseredData[i][j] = json.getString(jsonName[j]);
}
}
for(int i=0;i<parseredData.length;i++)
{
Log.i("Analyzed JSON Data"+i+":",parseredData[i][0]);
Log.i("Analyzed JSON Data"+i+":",parseredData[i][1]);
Log.i("Analyzed JSON Data"+i+":",parseredData[i][2]);
}
return parseredData;
}catch (JSONException e){
e.printStackTrace();
return null;
}
}
}
用户.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8" import = "org.json.simple.*"%>
<%@ page import ="java.sql.*" %>
<%
String id = request.getParameter("id");
String pw = request.getParameter("pw");
JSONObject jsonMain = new JSONObject();
JSONArray jArray = new JSONArray();
JSONObject jObject = new JSONObject();
Class.forName("com.mysql.jdbc.Driver");
try{
Connection conn = DriverManager.getConnection(
"jdbc:mysql://IP address/dbname", "admin", "1234");
Statement stmt = conn.createStatement();
String query = "select * from MEMBER";
ResultSet rs = stmt.executeQuery(query);
int i =0;
while(rs.next())
{
String _id = rs.getString("id");
String _pw = rs.getString("pw");
if(id.equals(_id)&&pw.equals(_pw)){
i =1;
jObject.put("msg1", "succed");
jObject.put("msg2", "two");
jObject.put("msg3", "three");
}
}
if(i==0){
jObject.put("msg1", "failed");
jObject.put("msg2", "two");
jObject.put("msg3", "three");
}
stmt.close();
conn.close();
jArray.add(0,jObject);
jsonMain.put("List",jArray);
out.println(jsonMain.toJSONString());
}catch(Exception e){
}
%>
日志猫
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test I/whole content from Server: <!DOCTYPE html><html><head><title>Apache Tomcat/8.0.33 - Error report</title><style type="text/css">H1 {font-family:Tahoma,Arial,sans-serif;color:white;background-color:#525D76;font-size:22px;} H2 {font-family:Tahoma,Arial,sans-serif;color:white;background-color:#525D76;font-size:16px;} H3 {font-family:Tahoma,Arial,sans-serif;color:white;background-color:#525D76;font-size:14px;} BODY {font-family:Tahoma,Arial,sans-serif;color:black;background-color:white;} B {font-family:Tahoma,Arial,sans-serif;color:white;background-color:#525D76;} P {font-family:Tahoma,Arial,sans-serif;background:white;color:black;font-size:12px;}A {color : black;}A.name {color : black;}.line {height: 1px; background-color: #525D76; border: none;}</style> </head><body><h1>HTTP Status 404 - /Test_Json/User.jsp</h1><div class="line"></div><p><b>type</b> Status report</p><p><b>message</b> <u>/Test_Json/User.jsp</u></p><p><b>description</b> <u>The requested resource is not available.</u></p><hr class="line"><h3>Apache Tomcat/8.0.33</h3></body></html>
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: org.json.JSONException: Value <!DOCTYPE of type java.lang.String cannot be converted to JSONObject
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at org.json.JSON.typeMismatch(JSON.java:111)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at org.json.JSONObject.<init>(JSONObject.java:160)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at org.json.JSONObject.<init>(JSONObject.java:173)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at com.example.user.nacho_http_connection_test.MainActivity.jsonParserList(MainActivity.java:126)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at com.example.user.nacho_http_connection_test.MainActivity.login_btn(MainActivity.java:66)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at java.lang.reflect.Method.invoke(Native Method)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at java.lang.reflect.Method.invoke(Method.java:372)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at android.view.View$1.onClick(View.java:4015)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at android.view.View.performClick(View.java:4780)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at android.view.View$PerformClick.run(View.java:19866)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at android.os.Handler.handleCallback(Handler.java:739)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at android.os.Handler.dispatchMessage(Handler.java:95)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at android.os.Looper.loop(Looper.java:135)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at android.app.ActivityThread.main(ActivityThread.java:5254)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at java.lang.reflect.Method.invoke(Native Method)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at java.lang.reflect.Method.invoke(Method.java:372)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
05-03 09:10:48.031 3982-3982/com.example.user.nacho_http_connection_test W/System.err: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
05-03 09:10:48.032 3982-3982/com.example.user.nacho_http_connection_test D/AndroidRuntime: Shutting down VM
--------- beginning of crash
05-03 09:10:48.032 3982-3982/com.example.user.nacho_http_connection_test E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.user.nacho_http_connection_test, PID: 3982
java.lang.IllegalStateException: Could not execute method of the activity
at android.view.View$1.onClick(View.java:4020)
at android.view.View.performClick(View.java:4780)
at android.view.View$PerformClick.run(View.java:19866)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5254)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
Caused by: java.lang.reflect.InvocationTargetException
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at android.view.View$1.onClick(View.java:4015)
at android.view.View.performClick(View.java:4780)
at android.view.View$PerformClick.run(View.java:19866)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5254)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
Caused by: java.lang.NullPointerException: Attempt to read from null array
at com.example.user.nacho_http_connection_test.MainActivity.login_btn(MainActivity.java:75)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at android.view.View$1.onClick(View.java:4015)
at android.view.View.performClick(View.java:4780)
at android.view.View$PerformClick.run(View.java:19866)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5254)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
05-03 09:10:52.844 3982-3982/com.example.user.nacho_http_connection_test I/Process: Sending signal. PID: 3982 SIG: 9
如有任何帮助,我们将不胜感激。
最佳答案
您正在发送 HTML(在 Jsp 中)并期望在 Android Activity 中发送 JSON。确保http://IP address/Test_Json/User.jsp/"?id="+ +&pw="将返回 Json 响应。
关于java - Android-JSP org.json.JSONException : Value <! java.lang.String 类型的 DOCTYPE 无法转换为 JSONObject,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37001929/
我正在审查一家海外开发公司为我们制作的一些 html。他们在外部脚本加载标签内使用注释——据我所知,这只对非常老的 javascript 不敏感的浏览器有用,他们曾经将脚本呈现为文本——是否有任何现代
这个问题在这里已经有了答案: Are HTML comments inside script tags a best practice? [closed] (10 个答案) 关闭 8 年前。 我正在
哪个更好用或者更方便: ... 或 ... 最佳答案 你真的需要类型属性吗?如果您使用的是 HTML5,则不会。否则,是的。 HTML 4.01 和 XHTML 1.0 指定了 type属性是必需的,
哪个更好用或者更方便: ... 或 ... 最佳答案 你真的需要类型属性吗?如果您使用的是 HTML5,则不会。否则,是的。 HTML 4.01 和 XHTML 1.0 指定了 type属性是必需的,
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: Why don't self-closing script tags work? 我刚刚发现 HTML 中的
这个问题在这里已经有了答案: What does in XML mean? (13 个答案) 关闭 8 年前。 我不熟悉 XML 及其相关技术。 这个 CDATA 标签总是在开头,然后是一些东西
我最近遇到这个问题,我试图在我的 HTML 页面中导入多个 js 文件,如下 - 但我面临的问题是,它只加载第一个 js 文件,而其余的 js 文件没有加载。我还检查了浏览器中的网络部分,剩下的
Duplicate Why don’t self-closing script tags work? 我正在编写一个 ASP.net 页面,它在 JS 文件中有一些用于客户端身份验证的 Javascr
在这个博客中, http://www.bswebdev.com/2008/12/javascript-change-input-box-type-to-password/我发现以下代码段用于在 IE6
为什么以下行在许多浏览器(mozilla、IE)中不起作用? 为什么一定要这样设置? 最近我将我的项目从 XHTML 转换为 HTML5,我遇到了一些小但令人不安的不兼容性。 最佳答案 虽然脚本元
是什么意思?这个和其他类似的 IE 代码行在 HTML5 文档中意味着什么? 如果我必须使某些 css 功能与 IE8 或更低版本兼容,上面提到的代码行或其中提到的 html 类是否有帮助? 如果
请说明 之间有什么区别标记和 标签。 Page title 如果两者都使用,哪个最优先? 我观察到一些网站同时具有 和 tags 和 两者相同,这是预期的,请确认? 如果我们不使用 标签标题,我
这个问题已经有答案了: Why don't self-closing script elements work? (12 个回答) 已关闭 7 年前。 经过两天的 Angular 与 Webpack
我有这个代码: .roll-link { display: inline-block; overflow: hidden; vertical-align: top;
我在 the HTML 4.01 specification at w3.org 中阅读了有关 HTML 文档结构的内容.然后我偶然发现了这段代码;它看起来像某种定义。你们中的任何人都可以详细说明它的
我正在网站上工作 http://palacechemicals.co.uk/它以某种方式感染了恶意(但良性)的 JavaScript 行: 在第 251 行。脚本尝试加载的 URL 返回 404,但
尝试解析引号内的 JSON 键名称,包括转义引号。我的想法是:在引号之间取任何内容而不是,并以\ 为前缀 (?
我有个小问题。 我正在尝试使用 在 IE 中打开时有条件地设置一个唯一的 css 文件,但它不起作用。 我试着穿上 , 关于 , 关于 footer .我尝试更改我的 IE 版本,但没有任何效果。
我是 Blogger 博客用户。我曾经看到一个在 CDATA 标记内定位脚本的模板,如下所示: /**/ 虽然,我之前看到过类似的代码,如下所示: // 唯一不同的是/*
让我放心。我刚学 HTML。 根据http://www.w3.org/TR/html-markup/syntax.html#comments以及我见过的许多其他网站,例如 http://www.w3s
我是一名优秀的程序员,十分优秀!