【发布时间】:2019-01-06 20:41:04
【问题描述】:
我正在开发一个 web 应用程序,在后端使用 spring-boot,在前端使用 reactjs,我使用 webpack 和 babel 来捆绑 react 文件。环境设置没问题,前端工作正常。但是我卡在前端和后端之间的通信上。
显然,我的问题是如何从 Spring Boot 中获取数据以在 React 组件中为它们提供服务?
这是我的@RestController class:
我试图在互联网上进行全面研究,去了这个 tuto https://spring.io/guides/tutorials/react-and-spring-data-rest/ 那里他们解释得很清楚,但有些东西很复杂,我没有很好地记住,所以我可以开发自己的代码,要访问后端数据,他们使用一行代码
`client({method: 'GET', path: '/api/employees'}).done(response => {
this.setState({employees: response.entity._embedded.employees});`
但是这段代码不清楚。这个问题也不是这个How to integrate ReactJS with spring Boot 的重复,因为它没有回答它。任何人都可以帮助我。
package scholar.reactspringwebpack.controllers;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import scholar.reactspringwebpack.entities.PrmEntity;
import scholar.reactspringwebpack.services.PrmServices;
import java.util.List;
@RestController
@CrossOrigin
public class DataController {
@Autowired
PrmServices prmServices;
@GetMapping(value = "/all")
public List<PrmEntity>readAll(){
return prmServices.readAllUsers();
}
}`
and here is my reactjs component :
import React, { Component } from 'react';
import axios from 'axios';
class SignupForm extends Component {
state={
fname: "",
lname: "",
depart: "",
username: "",
password: "",
account_type: ""
}
componentDidMount(){
axios.get("http://localhost:8080/all").then(res =>{
const persons = res.data;
this.setState({
fname:persons.fname,
lname:persons.lname,
depart:persons.depart,
username:persons.username,
password:persons.password,
account_type:persons.account_type
});
});
}
render() {
const {users} = this.state;
console.log(users);
// const userList = users.map(user=>{
// return(
// <table>
// <thead>
// <tr>
// <th>fname</th>
// <th>lname</th>
// <th>depart</th>
// <th>username</th>
// <th>password</th>
// <th>account_type</th>
// </tr>
// </thead>
// <tbody>
// <tr>
// <td>{user.fname}</td>
// <td>{user.lname}</td>
// <td>{user.depart}</td>
// <td>{user.username}</td>
// <td>{user.password}</td>
// <td>{user.account_type}</td>
// </tr>
// </tbody>
// </table>
// )
// })
return (
<div className="container">
<div className="row">
<div className="col-md-6 text-center signup-form ml-auto mr-5 card">
<div className="card-header">
<h3 className="text-info">Sign Up Form</h3>
</div>
<div className="card-body">
<form className="container">
<div className="form-group form-row">
<input
type="text"
name="fname"
placeholder="Enter family name"
className="input-text bg-transparent text-white form-control form-control-sm"
/>
</div>
<div className="form-group form-row">
<input
type="text"
name="lname"
placeholder="Enter last name"
className="input-text bg-transparent text-white form-control form-control-sm" />
</div>
<div className="form-group form-row">
<select
name="depart"
className="input-text bg-transparent text-info custom-select custom-select-sm">
<option value="">--Select your department--</option>
<option value="administration">Administration</option>
<option value="anaesthesia">Anaesthesia</option>
<option value="palliative_care">Palliative care</option>
<option value="petite_chgie">Petite chirirugie</option>
</select>
</div>
<div className="form-group form-row">
<input
type="text"
name="username"
placeholder="Enter your username"
className="input-text bg-transparent text-white form-control form-control-sm"
/>
</div>
<div className="form-group form-row">
<input
type="password"
name="password"
placeholder="Enter password"
className="input-text bg-transparent text-white form-control form-control-sm"
/>
</div>
<div className="form-group form-row">
<input
type="password"
name="confirm_password"
placeholder="Confirm your password"
className="input-text bg-transparent text-white form-control form-control-sm" />
</div>
<div className="">
<select
name="account_type"
className="input-text bg-transparent text-info custom-select custom-select-sm">
<option value="">--Select your account type--</option>
<option value="normal_user">Normal user</option>
<option value="data_manager">Data Manager</option>
<option value="head_of_dpt">Head of department</option>
<option value="system_admin">System administrator</option>
</select>
</div>
<div className="form-group form-row">
<button name="signup_btn" className="mt-2 btn btn-block btn-outline-primary btn-sm">Sign up</button>
</div>
</form>
</div>
</div>
</div>
</div>
)
}
}
export default SignupForm;
【问题讨论】:
-
如果您对
GETcURL(或任何其他HTTP 客户端)在http://localhost:<PORT>/api/employees/all/上执行,您目前会得到什么响应?此外,您是否在其他地方定义了上下文/api/employees?如果没有,您可能想说:@RestController("/api/employees")first。
标签: java spring reactjs spring-boot spring-mvc