- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个通过 JSON 将数据(用户名、电子邮件)发送到数据库的应用程序。此后,用户会收到一封电子邮件,其中包含来自 PHP 脚本的登录数据,这每次都有效。但此后应用程序崩溃了。我不明白为什么。一切正常,只是崩溃了。
reglogin.java(抱歉,它不是很干净......)
public class loginreg extends Activity {
public static final int MENU_REGLOGIN = Menu.FIRST;
// Progress Dialog
private ProgressDialog pDialog;
JSONParser jsonParser = new JSONParser();
EditText inputUsername, inputEMail;
TextView reguser, regemail;
String inserted, inserted_email, failedinput, txt_inputUsername, message;
static String txt_inputEMail;
int inserted_length, fail;
boolean b;
int userok = 0;
static int emailok = 0;
static final String ALLOWED_CHARACTERS ="0123456789qwertyuiopasdfghjklzxcvbnmABCDEFGHIJKLMNOPQRSTUVWXYZ";
// url to create new product
private static String url_create_product = "http://192.168.99.108/cheateapp/new_user.php";
// JSON Node names
private static final String TAG_SUCCESS = "success";
private static final String TAG_MESSAGE = "message";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_CUSTOM_TITLE);
setContentView(R.layout.login_reg);
getWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE,R.layout.header_loginreg);
// Create button
Button btnCreateProduct = (Button) findViewById(R.id.cmd_reg);
// Edit Text
inputUsername = (EditText) findViewById(R.id.edit_reguser);
inputEMail = (EditText) findViewById(R.id.edit_regemail);
regemail = (TextView) findViewById(R.id.txt_regemail);
reguser = (TextView) findViewById(R.id.txt_reguser);
inputUsername.addTextChangedListener(new TextWatcher(){
public void afterTextChanged(Editable s) {
inserted = inputUsername.getText().toString().trim().replace(" ", "");
inserted_length = inserted.length();
failedinput = "";
fail = 0;
Pattern p = Pattern.compile("[^a-z0-9 ]", Pattern.CASE_INSENSITIVE);
Matcher m = p.matcher(inserted);
b = m.find();
reguser.setOnClickListener(null);
check_username(inserted, inserted_length);
}
public void beforeTextChanged(CharSequence s, int start, int count, int after){}
public void onTextChanged(CharSequence s, int start, int before, int count){}
});
inputEMail.addTextChangedListener(new TextWatcher(){
public void afterTextChanged(Editable s) {
inserted_length = inputEMail.getText().toString().length();
inserted_email = inputEMail.getText().toString();
regemail.setOnClickListener(null);
if(isEmailValid(inserted_email)){
regemail.setText(" OK");
regemail.setTextColor(Color.GREEN);
} else {
regemail.setText(" X");
regemail.setTextColor(Color.RED);
regemail.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
Toast.makeText(getApplicationContext(), "Keine gültige E-Mail Adresse!", Toast.LENGTH_SHORT).show();
}
});
}
//Check if field is empty
if(inserted_length == 0){
regemail.setText(" -");
regemail.setTextColor(Color.WHITE);
emailok = 0;
}
}
public void beforeTextChanged(CharSequence s, int start, int count, int after){}
public void onTextChanged(CharSequence s, int start, int before, int count){}
});
// button click event
btnCreateProduct.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
// creating new product in background thread
if(userok == 1 && emailok == 1){
new CreateNewUser().execute();
} else {
Toast.makeText(getApplicationContext(), "Benutzerdaten überprüfen!", Toast.LENGTH_SHORT).show();
}
}
});
}
@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;
}
/**
* Background Async Task to Create new product
* */
class CreateNewUser extends AsyncTask<String, String, String> {
/**
* Before starting background thread Show Progress Dialog
* */
@Override
protected void onPreExecute() {
super.onPreExecute();
Log.v("TEST", "1");
pDialog = new ProgressDialog(loginreg.this);
Log.v("TEST", "1");
pDialog.setMessage("Registrieren..");
Log.v("TEST", "1");
pDialog.setIndeterminate(false);
Log.v("TEST", "1");
pDialog.setCancelable(true);
Log.v("TEST", "1");
pDialog.show();
Log.v("TEST", "1");
}
/**
* Creating product
* */
protected String doInBackground(String... args) {
Log.v("TEST", "1");
String BENUTZER_NAME = txt_inputUsername;
String BENUTZER_PW = getRandomString(5);
String BENUTZER_EMAIL = txt_inputEMail;
Log.v("TEST", "1");
// Building Parameters
List<NameValuePair> params = new ArrayList<NameValuePair>();
params.add(new BasicNameValuePair("BENUTZER_NAME", BENUTZER_NAME));
params.add(new BasicNameValuePair("BENUTZER_EMAIL", BENUTZER_EMAIL));
params.add(new BasicNameValuePair("BENUTZER_PW", BENUTZER_PW));
Log.v("TEST", "1");
// getting JSON Object
// Note that create product url accepts POST method
JSONObject json = jsonParser.makeHttpRequest(url_create_product,
"POST", params);
Log.v("TEST", "12");
// check log cat fro response
//Log.d("Create Response", json.toString());
Log.v("TEST", "1");
// check for success tag
try {
Log.v("TEST", "1");
int success = json.getInt(TAG_SUCCESS);
Log.v("TEST", "1");
message = json.getString(TAG_MESSAGE);
Log.v("TEST", "1");
if (success == 1) {
// successfully created product
Log.v("TEST", "1");
} else {
// failed to create product
Log.v("TEST", "1");
}
} catch (JSONException e) {
e.printStackTrace();
}
return null;
}
/**
* After completing background task Dismiss the progress dialog
* **/
protected void onPostExecute(String file_url) {
// dismiss the dialog once done
Log.v("TEST", "1");
pDialog.dismiss();
Log.v("TEST", "1");
Toast.makeText(getApplicationContext(), message, Toast.LENGTH_SHORT).show();
Log.v("TEST", "1");
finish();
}
}
public void check_username(String username, int username_length){
//Check if too less signs
if(username_length < 4){
failedinput = "Benutzername muss mehr als 4 Zeichen enthalten.\n";
fail = fail + 1;
}
//Check if too much signs
if(username_length > 20){
failedinput = failedinput + "Benutzername muss weniger als 20 Zeichen enthalten.\n";
fail = fail + 1;
}
if(b){
failedinput = failedinput + "Benutzername darf keine Sonderzeichen enthalten.\n";
fail = fail + 1;
}
if(fail > 0){
reguser.setText(" X");
reguser.setTextColor(Color.RED);
userok = 0;
reguser.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
Toast.makeText(getApplicationContext(), failedinput, Toast.LENGTH_SHORT).show();
}
});
} else {
reguser.setText(" OK");
reguser.setTextColor(Color.GREEN);
txt_inputUsername = username.trim().replace(" ", "");
userok = 1;
}
//Check if field is empty
if(inserted_length == 0){
reguser.setText(" -");
reguser.setTextColor(Color.WHITE);
userok = 0;
}
}
public static boolean isEmailValid(String email) {
boolean isValid = false;
String expression = "^[\\w\\.-]+@([\\w\\-]+\\.)+[A-Z]{2,4}$";
CharSequence inputStr = email;
Pattern pattern = Pattern.compile(expression, Pattern.CASE_INSENSITIVE);
Matcher matcher = pattern.matcher(inputStr);
if (matcher.matches()) {
isValid = true;
txt_inputEMail = email;
emailok = 1;
} else {
emailok = 0;
}
return isValid;
}
private static String getRandomString(final int sizeOfRandomString)
{
final Random random=new Random();
final StringBuilder sb=new StringBuilder();
for(int i=0;i<sizeOfRandomString;++i)
sb.append(ALLOWED_CHARACTERS.charAt(random.nextInt(ALLOWED_CHARACTERS.length())));
return sb.toString();
}
}
日志猫:
09-20 16:36:53.600: D/SensorManager(978): unregisterListener:: Listener= android.view.OrientationEventListener$SensorEventListenerImpl@42245de0
09-20 16:36:53.600: D/Sensors(978): Remain listener = Sending .. normal delay 200ms
09-20 16:36:53.600: I/Sensors(978): sendDelay --- 200000000
09-20 16:36:53.600: D/SensorManager(978): JNI - sendDelay
09-20 16:36:53.600: I/SensorManager(978): Set normal delay = true
09-20 16:36:56.850: E/JSON Parser(978): Error parsing data org.json.JSONException: Value 2013-09-20 of type java.lang.String cannot be converted to JSONObject
09-20 16:36:56.850: V/TEST(978): 12
09-20 16:36:56.850: V/TEST(978): 1
09-20 16:36:56.850: V/TEST(978): 1
09-20 16:36:56.855: W/dalvikvm(978): threadid=13: thread exiting with uncaught exception (group=0x412a32a0)
09-20 16:36:56.855: E/AndroidRuntime(978): FATAL EXCEPTION: AsyncTask #1
09-20 16:36:56.855: E/AndroidRuntime(978): java.lang.RuntimeException: An error occured while executing doInBackground()
09-20 16:36:56.855: E/AndroidRuntime(978): at android.os.AsyncTask$3.done(AsyncTask.java:299)
09-20 16:36:56.855: E/AndroidRuntime(978): at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
09-20 16:36:56.855: E/AndroidRuntime(978): at java.util.concurrent.FutureTask.setException(FutureTask.java:124)
09-20 16:36:56.855: E/AndroidRuntime(978): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
09-20 16:36:56.855: E/AndroidRuntime(978): at java.util.concurrent.FutureTask.run(FutureTask.java:137)
09-20 16:36:56.855: E/AndroidRuntime(978): at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
09-20 16:36:56.855: E/AndroidRuntime(978): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
09-20 16:36:56.855: E/AndroidRuntime(978): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
09-20 16:36:56.855: E/AndroidRuntime(978): at java.lang.Thread.run(Thread.java:856)
09-20 16:36:56.855: E/AndroidRuntime(978): Caused by: java.lang.NullPointerException
09-20 16:36:56.855: E/AndroidRuntime(978): at spicysoftware.cheatapp.loginreg$CreateNewUser.doInBackground(loginreg.java:196)
09-20 16:36:56.855: E/AndroidRuntime(978): at spicysoftware.cheatapp.loginreg$CreateNewUser.doInBackground(loginreg.java:1)
09-20 16:36:56.855: E/AndroidRuntime(978): at android.os.AsyncTask$2.call(AsyncTask.java:287)
09-20 16:36:56.855: E/AndroidRuntime(978): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
09-20 16:36:56.855: E/AndroidRuntime(978): ... 5 more
09-20 16:37:07.290: E/WindowManager(978): Activity spicysoftware.cheatapp.loginreg has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@429be460 that was originally added here
09-20 16:37:07.290: E/WindowManager(978): android.view.WindowLeaked: Activity spicysoftware.cheatapp.loginreg has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@429be460 that was originally added here
09-20 16:37:07.290: E/WindowManager(978): at android.view.ViewRootImpl.<init>(ViewRootImpl.java:412)
09-20 16:37:07.290: E/WindowManager(978): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:312)
09-20 16:37:07.290: E/WindowManager(978): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:224)
09-20 16:37:07.290: E/WindowManager(978): at android.view.WindowManagerImpl$CompatModeWrapper.addView(WindowManagerImpl.java:149)
09-20 16:37:07.290: E/WindowManager(978): at android.view.Window$LocalWindowManager.addView(Window.java:554)
09-20 16:37:07.290: E/WindowManager(978): at android.app.Dialog.show(Dialog.java:277)
09-20 16:37:07.290: E/WindowManager(978): at spicysoftware.cheatapp.loginreg$CreateNewUser.onPreExecute(loginreg.java:166)
09-20 16:37:07.290: E/WindowManager(978): at android.os.AsyncTask.executeOnExecutor(AsyncTask.java:586)
09-20 16:37:07.290: E/WindowManager(978): at android.os.AsyncTask.execute(AsyncTask.java:534)
09-20 16:37:07.290: E/WindowManager(978): at spicysoftware.cheatapp.loginreg$3.onClick(loginreg.java:130)
09-20 16:37:07.290: E/WindowManager(978): at android.view.View.performClick(View.java:4223)
09-20 16:37:07.290: E/WindowManager(978): at android.view.View$PerformClick.run(View.java:17275)
09-20 16:37:07.290: E/WindowManager(978): at android.os.Handler.handleCallback(Handler.java:615)
09-20 16:37:07.290: E/WindowManager(978): at android.os.Handler.dispatchMessage(Handler.java:92)
09-20 16:37:07.290: E/WindowManager(978): at android.os.Looper.loop(Looper.java:137)
09-20 16:37:07.290: E/WindowManager(978): at android.app.ActivityThread.main(ActivityThread.java:4898)
09-20 16:37:07.290: E/WindowManager(978): at java.lang.reflect.Method.invokeNative(Native Method)
09-20 16:37:07.290: E/WindowManager(978): at java.lang.reflect.Method.invoke(Method.java:511)
09-20 16:37:07.290: E/WindowManager(978): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1008)
09-20 16:37:07.290: E/WindowManager(978): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:775)
09-20 16:37:07.290: E/WindowManager(978): at dalvik.system.NativeStart.main(Native Method)
new_user.php
<?php
/*
* Following code will create a new product row
* All product details are read from HTTP Post Request
*/
// array for JSON response
$response = array();
include("send_mail.php");
// check for required fields
if (isset($_POST['BENUTZER_NAME']) && isset($_POST['BENUTZER_EMAIL'])) {
$username = $_POST['BENUTZER_NAME'];
$useremail = $_POST['BENUTZER_EMAIL'];
$userpw = $_POST['BENUTZER_PW'];
// include db connect class
require_once 'db_connect.php';
// connecting to db
$db = new DB_CONNECT();
// check if user exists
$checkifuserexists = "SELECT COUNT(*) num FROM benutzer WHERE BENUTZER_NAME = '" . mysql_real_escape_string($username) . "'";
$result = mysql_query($checkifuserexists) or die('error');
$row = mysql_fetch_assoc($result);
$checkifemailexists = "SELECT COUNT(*) nummail FROM benutzer WHERE BENUTZER_EMAIL = '" . mysql_real_escape_string($useremail) . "'";
$resultmail = mysql_query($checkifemailexists) or die('error');
$rowmail = mysql_fetch_assoc($resultmail);
if($row['num'] && $rowmail['nummail']) {
$response["success"] = 0;
$response["message"] = "Der Benutzer und die E-Mail Adresse existieren bereits!";
echo json_encode($response);
} else {
if($row['num']){
$response["success"] = 0;
$response["message"] = "Der Benutzer $username existiert bereits!";
echo json_encode($response);
} else {
if($rowmail['nummail']){
$response["success"] = 0;
$response["message"] = "Die E-Mail Adresse $useremail existiert bereits!";
echo json_encode($response);
}else{
// mysql inserting a new row
$result = mysql_query("INSERT INTO benutzer(BENUTZER_NAME, BENUTZER_EMAIL, BENUTZER_PASSWORT) VALUES('$username', '$useremail', '$userpw')");
// check if row inserted or not
if ($result) {
// successfully inserted into database
$response["success"] = 1;
$response["message"] = "Dein Benutzerkonto wurde erstellt!";
// echoing JSON response
echo json_encode($response);
send_email($username, $useremail, $userpw);
} else {
// failed to insert row
$response["success"] = 0;
$response["message"] = "Ein Fehler trat auf!.";
// echoing JSON response
echo json_encode($response);
}
}
}
}
} else {
// required field is missing
$response["success"] = 0;
$response["message"] = "Required field(s) is missing";
// echoing JSON response
echo json_encode($response);
}
?>
最佳答案
根据异常的行号,看起来 NullPointerException 发生在这一行:
int success = json.getInt(TAG_SUCCESS);
这意味着 json 对象为 null。由于您收到以下错误消息:
09-20 16:36:56.850: E/JSON Parser(978): Error parsing data org.json.JSONException: Value 2013-09-20 of type java.lang.String cannot be converted to JSONObject
看起来问题出在 JSon 对象的解码上。此错误表明您尝试将字符串转换为 JSONObject。我会确保您正确解析该对象。
关于java - 通过 JSON 和 PHP 发送电子邮件后出现 NullpointerException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18919586/
我正在将我的模板代码移植到 XTend。在某些时候,我在测试用例中有这种类型的条件处理: @Test def xtendIfTest() { val obj = new FD if (
我是新来的 kotlin , 当我开始 Null Safety 时,我对下面的情况感到困惑. There's some data inconsistency with regard to initia
我的应用程序一直在各种Android版本中保持良好状态。我有用户在Android 4.3、5.0、5.1和6.0上正常运行。但是,具有S7 Edge的用户刚刚更新了Android 7.0,将文本粘贴到
我使用的是最新版本的 LWUIT (1.5)。我在资源编辑器中设计了我的表单,然后将代码生成到 netbeans。问题是如果我想访问除表单之外的任何对象,我会收到此错误: java.lang.Null
更新: 我在 Fedora 21 上运行它。 SonarQube - 5.0。 SonarQube Runner - 2.4 更新 2:Findbugs v3.1,Java 插件 v2.8 更新3:
RecupData 我的类仅在 web 中返回 NullPointerException。我连接到 pgsql db 8.3.7 - 该脚本在“控制台”syso 中运行良好 - 但引发了测试 Web
我在 mac 上使用 Processing 2.08。我正在尝试使用文档中给出的 createShape 函数创建 PShape。 PShape s; void setup(){ size(500
我在 mac 上使用 Processing 2.08。我正在尝试使用文档中给出的 createShape 函数创建 PShape。 PShape s; void setup(){ size(500
每次运行此 jsp 时,都会收到以下错误异常: org.apache.jasper.JasperException: java.lang.NullPointerException root cause
Kotlin 在编译时有一个出色的 null 检查,使用分离到“可空?”和“不可为空”的对象。它有一个 KAnnotator 来帮助确定来自 Java 的对象是否可以为空。但是,如果 not-null
我有一个布局将显示一个TextView,用于显示一个滴答时间。我遵循了此链接中的代码 How to Display current time that changes dynamically for
Elasticsearch 1.4.1版(“lucene_version”:“4.10.2”) 我有一个像这样的文件: $ curl 'http://localhost:9200/blog/artic
这是我从另一个类调用函数的方法Selenium 设置已定义。 public void Transfer() throws Exception { System.out.println("\nTrans
我试图在主类中使用我在此类中创建的函数,但它崩溃并显示“警告:无法在根 0 处打开/创建首选项根节点 Software\JavaSoft\Prefsx80000002。 Windows RegCrea
这个问题已经有答案了: What is a NullPointerException, and how do I fix it? (12 个回答) 已关闭 3 年前。 我有一个 Java 代码,它将
我声明了两张牌: Card card1 = new Card('3', Card.Suit.clubs); Card card2 = new Card('T', Card.Suit.diamonds)
我编写了一段代码来解码 Base64 图像并在 javafx 中表示该图像。在我的 url base64 代码中不断变化。这就是我在 javafx 代码中使用任务的原因。但我收到错误:java.lan
我正在尝试使用 arrayList 的 arrayList 在 Java 中实现图形。 每当调用 addEdge 函数时,我都会收到 NullPointerException 。我似乎无法弄清楚为什么
我是 Java/android 的新手,所以很多这些术语都是外国的,但我愿意学习。我不打算详细介绍该应用程序,因为我认为它不相关。我目前的问题是,我使用了博客中的教程和代码 fragment ,并使我
我正在开发一个 Android 应用程序来在 Android developer guide 的帮助下录制视频.我程序上的所有代码都与此页面相同。 我在 之外定义了权限标签。 当应
我是一名优秀的程序员,十分优秀!