目录
//2.还需要注意在AndroidManifest里面修改权限问题,因为我们要访问模拟器以外的网络。(就是我们的电脑主机了,两个he'qi'lai算是一个局域网吧)
JS代码:注意事项web里面的哪个写的有:
//引入express框架
const { response } = require('express');
const express = require('express');
//路径处理模块
const path = require('path');
//MySql数据库连接模块
const mysql = require('mysql');
const connect = mysql.createConnection({
host:'localhost',
//数据库的用户名和密码
user:'root',
password:'kkk',
//数据库中的表名
database:'并列成绩排名',
//mysql数据库默认的端口
port:3306,
useConnectionPooling: true
});
//
//var result = null;
//按ID查询,返回结果;
async function queryByID(id){
//connect.connect();
return new Promise(
function(resolve,reject){
console.log("mysql has connnected");
var result;
var sql = 'select * from user where id = ' + id;
connect.query(sql,function (err, results) {
if(err){
console.log('[SELECT ERROR] - ',err.message);
return;
}
if(results)
{
for(var i = 0; i < results.length; i++)
{
result = null;
console.log("%d\t%s\t%s", i, results[i].name, results[i].email);
result = results[i].name +"||"+ results[i].email
resolve(result);
}
}
});
})
//connect.end();
}
//插入一条数据;
async function insertUser(name,passwd,email){
//connect.connect();
return new Promise(
function(resolve,reject){
console.log("mysql has connnected");
let sql = "insert into user (name,age,email)values(?,?,?)";//?是占位符
//设置参数
let params=[name,passwd,email];
connect.query(sql,params,(err,result)=>{
if (err) {
console.error("插入失败" + err.message);
result;
}else{
console.log("插入成功");
resolve("插入成功");
}
});
})
//connect.end();
}
//创建Web服务器
const app = express();
//cors跨域共享资源
//导入cors模块
const cors = require('cors');
//注册 cors 全局模块
app.use(cors())
//静态资源访问服务功能
//path.join()用于把多个路径片段拼接成一个完整的路径字符串
app.use(express.static(path.join(__dirname,'public')))
//对应get
app.get('/test',(req,res)=>{
queryByID(req.query.id).then(rsp => {
res.send('发送:id=' + req.query.id + '|name=' + req.query.username +'|passwd='+ req.query.password + '|查询结果:' + rsp);
});
})
//对应insert
app.get('/insert',(req,res)=>{
insertUser(req.query.username,req.query.password,req.query.email).then(rsp => {
res.send('发送:id=' + req.query.id + '|name=' + req.query.username +'|passwd='+ req.query.password +'|email='+ req.query.email + '|查询结果:' + rsp);
});
})
//监听端口
app.listen(3000);
console.log('服务器启动成功,port:3000');
安卓代码:
//注意的有四点。
//1.不但需要注意IP的问题
//2.还需要注意在AndroidManifest里面修改权限问题,因为我们要访问模拟器以外的网络。(就是我们的电脑主机了,两个he'qi'lai算是一个局域网吧)
//3.还需要加线程:将代码再线程里面写。
//4.第二种从线程中传递数据的方法
//注意的有四点。
//不但需要注意IP的问题
//还需要注意在AndroidManifest里面修改权限问题,因为我们要访问模拟器以外的网络。(就是我们的电脑主机了,两个he'qi'lai算是一个局域网吧)
//还需要加线程:将代码再线程里面写。
//第二种从线程中传递数据的方法
public class MainActivity extends AppCompatActivity {
TextView tv_msg;
ImageView img_pic;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
tv_msg = findViewById(R.id.tv_msg);
img_pic = findViewById(R.id.img_pic);
}
public void requestMsg(View view) {
new Thread(new Runnable() {
@Override
public void run() {
BufferedReader bufferedReader =null;
try {
//对于模拟器来说127.0.0.1就是他自己,但是我们的数据放在真机电脑上,所以应该改成自己电脑的IP。
// 平时我们网页可以用locahost,或者127.0.0.1都可以,但是这个是在模拟器里面,所以应该连接真机的IP。
URL url = new URL("http://192.168.68.189:3000/test?id=1&username=suntex&passwd=123456");
HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
//设置网络连接超时的时间
urlConnection.setConnectTimeout(1000*10);
urlConnection.setRequestMethod("GET");
urlConnection.setRequestProperty("Accept-Language","zh-CN,zh;q=0.9");
urlConnection.setRequestProperty("Accept","*/*");
urlConnection.connect();
int code = urlConnection.getResponseCode();
if(code== HttpURLConnection.HTTP_OK){
InputStream inputStream =urlConnection.getInputStream();
bufferedReader = new BufferedReader(new InputStreamReader(inputStream));
String msg = bufferedReader.readLine();
Log.d("wang","服务器驱动"+msg);
Bitmap bitmap = BitmapFactory.decodeStream(inputStream);
//以前线程想要再页面显示文字的话,只能用handler传递数据出去,再显示,但是第二种方法可以这样
runOnUiThread(new Runnable() {
@Override
public void run() {
tv_msg.setText(msg);
}
});
}
} catch (Exception e) {
e.printStackTrace();
}
}
}).start();
}
//显示图片
public void requestImg(View view) {
new Thread(new Runnable() {
@Override
public void run() {
BufferedReader bufferedReader =null;
try {
//对于模拟器来说127.0.0.1就是他自己,但是我们的数据放在真机电脑上,所以应该改成自己电脑的IP。
// 平时我们网页可以用locahost,或者127.0.0.1都可以,但是这个是在模拟器里面,所以应该连接真机的IP。
URL url = new URL("https://tse2-mm.cn.bing.net/th/id/OIP-C.QFdwl07_aviM1ch2KpyyFgHaEo?pid=ImgDet&rs=1");
HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
//设置网络连接超时的时间
//因为从网上请求的所以网差的时候会很慢,所以变长一点
urlConnection.setConnectTimeout(10000*10);
urlConnection.setRequestMethod("GET");
urlConnection.setRequestProperty("Accept-Language","zh-CN,zh;q=0.9");
urlConnection.setRequestProperty("Accept","*/*");
urlConnection.connect();
int code = urlConnection.getResponseCode();
if(code== HttpURLConnection.HTTP_OK){
InputStream inputStream =urlConnection.getInputStream();
//读取图片流
Bitmap bitmap = BitmapFactory.decodeStream(inputStream);
//以前线程想要再页面显示文字的话,只能用handler传递数据出去,再显示,但是第二种方法可以这样
runOnUiThread(new Runnable() {
@Override
public void run() {
img_pic.setImageBitmap(bitmap);
}
});
}
} catch (Exception e) {
e.printStackTrace();
}
}
}).start();
}
}
<!-- //下方这一行是加上去的权限,为了可以访问外面网络的IP-->
<!-- 这里是网络请求的意思-->
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<!-- 下方的这句话是明文的意思-->
<!-- android:usesCleartextTraffic="true"-->
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:usesCleartextTraffic="true"
android:forceQueryable="true"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/Theme.MyApplication">
需要在AndroidManifest加入两行获取权限的代码。