Unity同时充当移动端和后台的界面+Sevelet+Mysql+Tomcat 学生信息的录入
程序员文章站
2022-07-13 13:36:13
...
https://blog.csdn.net/qq_15267341/article/details/54598304
这个Demo中,Unity扮演两个角色:
unity做客户端界面,实现每个学生信息的录入unity再做一个界面,实现读取所有学生信息并且展示出来
JavaWeb中的Servlet负责接收处理和响应Unity发过来的请求
Mysql用于存储所有学生的信息
服务器: tomcat
下面就看看具体的实现步骤:
Utniy中学生录入信息界面如下:
Unity这边三个脚本:
下面这张图是在Mysql中建立数据库和数据表的信息
经过上面的准备工作,下面先来看看客户端发数据,服务器接收数据并处理,最后将接收的数据保存到数据库 这条线
移动端代码如下,当点击提交按钮后,就会调用tijiao这个方法:
服务器端用于接收和处理客户端信息的Servlet,如下:
客户提交几条信息后,数据库中保存信息如下:
下面接着来看看,客户端向服务器请求所有的个人信息,并将信息展示出来这条线
先把客户端的滚动视图搭建起来:
这张图的锚点之所以靠上对齐,就是防止场景中item数量太少时,item居中显示,这样就不好看
还有一个问题,就是当所有item的高度总和超出显示框后,就涉及到一个如何保证首次显示滚动视图顶对齐的问题,解决办法如下:
建一个预设体,并且新建一个脚本item,然后将脚本赋值给预设体
挂在预设体身上的脚本:
服务器处理客户端请求的servlet:
客户端展示的信息如下截图:
下面这个工具类用于注册数据库的驱动,以及获取和释放连接,是实际使用时,可以直接拷贝复用
package com.shujuku.mysql;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class source {
static String username;
static String pwd;
static String urlString;
static {
try {
Class.forName("com.mysql.jdbc.Driver");
username = "root";
pwd = "root";
urlString = "jdbc:mysql://localhost:3306/person";
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
//FR: 海涛高软(QQ技术交流群:386476712)
public static Connection getConnection() throws Exception { //获取一个连接
Connection connection = DriverManager.getConnection(urlString,
username, pwd);
return connection;
}
public static void shifang(Connection con, PreparedStatement st, ResultSet rs) { //资源释放
if (rs != null) {
try {
rs.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
if (st != null) {
try {
st.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
if (con != null) {
try {
con.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
}
}
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 66
- 67
- 68
下面这个工具类,主要负责数据库的操作(增删改查),在实际使用时,可以直接拷贝复用
package com.shujuku.mysql;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
public class dbTools {
public static void zeng(user u) throws Exception { //插
Connection con = source.getConnection();
String sql = "insert into biao01(name,shenGao,jiaXiang) values(?,?,?);";
PreparedStatement st = con.prepareStatement(sql);
st.setString(1, u.getName());
st.setFloat(2, u.getShenGao());
st.setString(3, u.getJiaXiang());
st.executeUpdate();
source.shifang(con, st, null);
}
public static void shan(int dd) throws Exception{ // 删
Connection con = source.getConnection();
String sql = "delete from biao01 where id=?";
PreparedStatement st = con.prepareStatement(sql);
st.setInt(1, dd);
st.executeUpdate();
source.shifang(con, st, null);
}
public static void gai(user u) throws Exception{ // 改
Connection con = source.getConnection();
String sql = "update biao01 set shenGao=? where name=?";
PreparedStatement st = con.prepareStatement(sql);
st.setFloat(1, Float.valueOf(u.getShenGao()));
st.setString(2, u.getName());
st.executeUpdate();
source.shifang(con, st, null);
}
public static void cha() throws Exception{ // 查
Connection con = source.getConnection();
String sql = "select * from biao01 ";
PreparedStatement st = con.prepareStatement(sql);
ResultSet rs=st.executeQuery();
List< user> list=new ArrayList<user>();
while(rs.next()){
String name=rs.getString("name");
float shenGao=rs.getFloat("shenGao");
String jiaXiang=rs.getString("jiaXiang");
user uu=new user(name,shenGao,jiaXiang);
list.add(uu);
}
source.shifang(con, st, rs);
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
服务器端用于封装一次请求信息的bean对象如下:
package com.shujuku.mysql;
public class user {
private int id;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
private String name;
private float shenGao;
private String jiaXiang;
public String getName() {
return name;
}
public void setName(String nameString) {
this.name = nameString;
}
public float getShenGao() {
return shenGao;
}
public void setShenGao(float shenGao) {
this.shenGao = shenGao;
}
public String getJiaXiang() {
return jiaXiang;
}
public void setJiaXiang(String jiaXiang) {
this.jiaXiang = jiaXiang;
}
public user(String aa, float bb, String cc) {
super();
this.name = aa;
this.shenGao = bb;
this.jiaXiang = cc;
}
public user() {
super();
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
备注:
客户端读取json用的是 LitJson插件
服务器端输出json字符串用的是阿里云开发的 fastjson插件
FR:海涛高软(QQ技术群:386476712)