从事一段时间Android的我,一般都是调用别人的接口来进行相关的开发,可是一直以来对于接口问题和后端开发的同窗争吵不休,没法肯定责任到底在谁,最终在这种状况下,我从新回到本身以前的Java开发,通过了两个小时的努力,完成了一个以springboot 为框架,其中集成了jpa,mysql的方式来完成。废话很少说了,直接上代码!
其中项目的依赖文件为 :
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>java
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <scope>runtime</scope> <optional>true</optional> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>runtime</scope> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> , application.properties 的配置文件为:
spring.datasource.url=jdbc:mysql://localhost:3306/zhiteng?characterEncoding=UTF-8&serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=password
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
#配置JPA
spring.jpa.show-sql=true
spring.jpa.hibernate.ddl-auto=updatemysql
bean 文件为:web
@Entity
public class User {br/>@Column
@Idbr/>@GeneratedValue()
int id;br/>@Column
public String userID;br/>@Column
public String name;br/>@Column
public String password;br/>@Column
public String userName;br/>@Column
public String nikeName;br/>@Column
public int age;br/>@Column
public String address;br/>@Email
@Column
public String Email;br/>@Column
String birthday;br/>@Column
public String userType;br/>@Column
public String userRule;br/>@Column
public String phoneNum;br/>@Column
public String userAccount;spring
}
JPA :sql
public interface UserJpa extends JpaRepository<User, String> {
long countUserByPhoneNum(String phoneNum);
}json
Controller:br/>@RestController
public class UserController {br/>@Autowired
UserJpa userJpa;后端
@RequestMapping(value = register) public Result register(@RequestParam("userName") String userName, @RequestParam("password") String password, String address, int age, String name, String userAccount, String Email, @RequestParam("userPhone") String userPhone, String nikeName) { Result result = new Result(); long tag = userJpa.countUserByPhoneNum(userPhone); if (tag > 0) { result.code = 201; result.msg = "用户已存在,能够直接登陆"; } else { User user = new User(); user.userID = SerialUtils.getUserId(); user.name = name; if (StringUtils.isEmpty(userAccount)) { user.userAccount = userName; } else { user.userAccount = userAccount; } user.phoneNum = userPhone; user.password = MyMD5Util.getMD5(password); if (StringUtils.isEmpty(nikeName)) { user.nikeName = "zhiteng" + userPhone.substring(userPhone.length() - 4); } else { user.nikeName = nikeName; } user.userName = userName; if (StringUtils.isEmpty(address)) { user.address = "陕西,渭南"; } else { user.address = address; } user.age = age; user.Email = Email; user.userType = UserType.common; user.userRule = UserRule.user; User u = userJpa.save(user); if (null == u) { result.code = 202; result.data = user; result.msg = "注册失败"; } else { result.code = 200; result.data = user; result.msg = "注册成功"; } } return result; }
}springboot
对于Controller中的各种注解解释以下:br/>@RestController将返回数据自动格式化为json文件
@RequestMapping 请求路径
@RequestParam 必传参数,
其余为非必传参数app