Hibernate用のモデルクラスはこれです
@Entity
@Table(name = "user", catalog = "userdb")
@JsonIgnoreProperties(ignoreUnknown = true)
public class User implements java.io.Serializable {
private Integer userId;
private String userName;
private String emailId;
private String encryptedPwd;
private String createdBy;
private String updatedBy;
@Id
@GeneratedValue(strategy = IDENTITY)
@Column(name = "UserId", unique = true, nullable = false)
public Integer getUserId() {
return this.userId;
}
public void setUserId(Integer userId) {
this.userId = userId;
}
@Column(name = "UserName", length = 100)
public String getUserName() {
return this.userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
@Column(name = "EmailId", nullable = false, length = 45)
public String getEmailId() {
return this.emailId;
}
public void setEmailId(String emailId) {
this.emailId = emailId;
}
@Column(name = "EncryptedPwd", length = 100)
public String getEncryptedPwd() {
return this.encryptedPwd;
}
public void setEncryptedPwd(String encryptedPwd) {
this.encryptedPwd = encryptedPwd;
}
public void setCreatedBy(String createdBy) {
this.createdBy = createdBy;
}
@Column(name = "UpdatedBy", length = 100)
public String getUpdatedBy() {
return this.updatedBy;
}
public void setUpdatedBy(String updatedBy) {
this.updatedBy = updatedBy;
}
}
Spring MVC コントローラーでは、DAO を使用してオブジェクトを取得し、JSON オブジェクトとして返すことができます。
@Controller
public class UserController {
@Autowired
private UserService userService;
@RequestMapping(value = "/getUser/{userId}", method = RequestMethod.GET)
@ResponseBody
public User getUser(@PathVariable Integer userId) throws Exception {
User user = userService.get(userId);
user.setCreatedBy(null);
user.setUpdatedBy(null);
return user;
}
}
ビュー部分はAngularJSを使用して行われるため、次のようなJSONが取得されます。
{
"userId" :2,
"userName" : "john",
"emailId" : "[email protected]",
"encryptedPwd" : "Co7Fwd1fXYk=",
"createdBy" : null,
"updatedBy" : null
}
暗号化されたパスワードを設定したくない場合は、そのフィールドも null に設定します。
しかし、私はこのようなことはしたくありません。すべてのフィールドをクライアント側に送信したくありません。パスワード、updatedby、createdbyフィールドを送信したくない場合は、結果のJSONは次のようになります。
{
"userId" :2,
"userName" : "john",
"emailId" : "[email protected]"
}
他のデータベース テーブルから取得された、クライアントに送信したくないフィールドのリスト。ログインしているユーザーに基づいて変更されます。どうすればよいでしょうか?
私の質問が理解できたと思います。
ベストアンサー1
@JsonIgnoreProperties("fieldname")
POJO に注釈を追加します。
または、@JsonIgnore
JSON をデシリアライズするときに無視するフィールドの名前の前に を使用することもできます。例:
@JsonIgnore
@JsonProperty(value = "user_password")
public String getUserPassword() {
return userPassword;
}