我试图将条形码扫描内容发布到mysql数据库中。我不理解我的错误,当我发送时没有显示错误,但仍然没有发布。最初显示php脚本但现在没有显示任何操作。这是代码。我真的卡在这里。下面的活动是XyzActivity.java
,post1.php
然后是activity_xyz.xml
。
XyzActivity.java
package com.example.boss.classattendance;
import android.app.ProgressDialog;
import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;
import com.android.volley.RequestQueue;
import com.android.volley.Request;
import com.android.volley.Response;
import com.android.volley.VolleyError;
import com.android.volley.toolbox.StringRequest;
import com.google.zxing.integration.android.IntentIntegrator;
import java.util.HashMap;
import java.util.Map;
import com.android.volley.toolbox.Volley;
public class XyzActivity extends AppCompatActivity implements
View.OnClickListener{
//private static final String TAG = "AbcActivity";
public static final String KEY_FORMAT = "scanFormat";
public static final String KEY_CONTENT = "scanContent";
private static final String URL_FOR_REGISTRATION =
"http://m.y.i.p/test/post1.php";
ProgressDialog progressDialog;
private TextView greetingTextView;
private Button scanBtn,post,Logout;
private TextView scan_format, scan_content;
String scanContent;
String scanFormat;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_xyz);
progressDialog = new ProgressDialog(this);
progressDialog.setCancelable(false);
Bundle bundle = getIntent().getExtras();
String user = bundle.getString("username");
greetingTextView = (TextView) findViewById(R.id.greeting_text_view);
greetingTextView.setText("Hello "+ user);
scanBtn = (Button)findViewById(R.id.scan_button);
scan_format = (TextView)findViewById(R.id.scan_format);
Logout=(Button)findViewById(R.id.logout_button);
scan_content = (TextView)findViewById(R.id.scan_content);
post=(Button)findViewById(R.id.post_button);
scanBtn.setOnClickListener(this);
post.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
submitForm();
}
});
Logout.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent i = new
Intent(getApplicationContext(),MainActivity.class);
startActivity(i);
}
});
}
public void onClick(View v){
if(v.getId()==R.id.scan_button){
com.google.zxing.integration.android.IntentIntegrator scanIntegrator
= new com.google.zxing.integration.android.IntentIntegrator(this);
scanIntegrator.initiateScan();
}}
public void onActivityResult(int requestCode, int resultCode, Intent
intent) {
com.google.zxing.integration.android.IntentResult scanningResult =
IntentIntegrator.parseActivityResult(requestCode, resultCode, intent);
if (scanningResult != null) {
scanContent = scanningResult.getContents();
scanFormat = scanningResult.getFormatName();
scan_format.setText("FORMAT: " + scanFormat);
scan_content.setText("CONTENT: " + scanContent);
}
else{
Toast toast = Toast.makeText(getApplicationContext(),
"No scan data received!", Toast.LENGTH_SHORT);
toast.show();
}
}
private void submitForm(){
final String scanContent = scan_content.getText().toString().trim();
final String scanFormat = scan_format.getText().toString().trim();
StringRequest stringRequest = new StringRequest(Request.Method.POST,
URL_FOR_REGISTRATION,
new Response.Listener<String>() {
@Override
public void onResponse(String response) {
Toast.makeText(XyzActivity.this,response,Toast.LENGTH_LONG).show();
}
},
new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Toast.makeText(XyzActivity.this,error.toString(),Toast.LENGTH_LONG).show();
}
}){
@Override
protected Map<String,String> getParams(){
Map<String,String> params = new HashMap<String, String>();
params.put(KEY_CONTENT,scanContent);
params.put(KEY_FORMAT,scanFormat);
return params;
}
};
RequestQueue requestQueue = Volley.newRequestQueue(this);
requestQueue.add(stringRequest);
}
}
post1.php
<?php
require_once 'android_login_connect.php';
$db = new android_login_connect();
$response = array("error" => FALSE);
if (isset($_POST['content']) && isset($_POST['format'])) {
$content = $_POST['content'];
$format = $_POST['format'];
$sql = "INSERT INTO post (content,format)
VALUES ('$KEY_CONTENT','$KEY_FORMAT')";
if(mysqli_query($con,$sql)){
echo ‘success’;
} else {
$response["error"] = TRUE;
$response["error_msg"] = "Unknown error occurred in registration!";
echo json_encode($response);
}
};
?>
activity_xyz.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:fillViewport="true"
android:gravity="center"
android:orientation="vertical"
android:paddingLeft="20dp"
android:paddingRight="20dp"
android:scrollbars="vertical"
android:weightSum="1">
<TextView
android:id="@+id/greeting_text_view"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="30dp"
android:text="Hello, User"
android:textColor="@android:color/black"
android:textSize="30dp"
android:textStyle="bold"
android:layout_weight="0.09" />
<Button
android:id="@+id/scan_button"
android:layout_width="match_parent"
android:layout_height="30dp"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:layout_marginTop="40dp"
android:background="@color/login_button_background"
android:text="SCAN"
android:textColor="@android:color/black"
android:textStyle="bold" />
<TextView
android:id="@+id/scan_format"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="40dp"
android:layout_weight="0.09"
android:text="Format"
android:textColor="@android:color/black"
android:textSize="20dp"
android:textStyle="bold" />
<TextView
android:id="@+id/scan_content"
android:layout_width="match_parent"
android:layout_height="23dp"
android:layout_marginTop="40dp"
android:text="Content"
android:textColor="@android:color/black"
android:textSize="20dp"
android:textStyle="bold" />
<Button
android:id="@+id/post_button"
android:layout_width="match_parent"
android:layout_height="30dp"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:layout_marginTop="40dp"
android:background="@color/login_button_background"
android:text="POST"
android:textColor="@android:color/black"
android:textStyle="bold" />
<Button
android:id="@+id/logout_button"
android:layout_width="match_parent"
android:layout_height="30dp"
android:layout_marginTop="40dp"
android:background="@color/login_button_background"
android:text="Sign Out!!"
android:textColor="@android:color/black"
android:textStyle="bold" />
</LinearLayout>
答案 0 :(得分:0)
$content = $_POST['content'];
$format = $_POST['format'];
$sql = "INSERT INTO post (content,format)
VALUES ('$KEY_CONTENT','$KEY_FORMAT')";
什么是$KEY_CONTENT
和$KEY_FORMAT
?
不应该是
$content = $_POST['content'];
$format = $_POST['format'];
$sql = "INSERT INTO post (content,format)
VALUES ('$content','$format')";