Как я могу убедиться, что передаваемые параметры не содержат содержимого межсайтовых сценариев

Я создаю веб-сервисы Rest, используя Spring и передаю параметры методу из класса модели.

Мои входные параметры такие

{
    "user_id": 23,
    "user_email_id": "[email protected]",
    "user_password": "fdsdsdf",
    "firstname": "<script>window.alert(‘surprise!’);</script>",
    "lastname": "kdfgkdf",
    "mobile_number": "1414141414",
    "user_status": 1,
    "isdeleted": 0,
    "created_by": 1,
    "profile_picturename": "kfksdjfhksjd",
    "address": "sfdsdfsd"
}

& Мой метод контроллера ReST такой же, как

@RequestMapping(value = "/validate", method = RequestMethod.POST, consumes = MediaType.APPLICATION_JSON_VALUE, produces = MediaType.APPLICATION_JSON_VALUE)
public Object AddUser(@Valid @RequestBody UserInputModel userInputModel, BindingResult br, HttpServletResponse response) throws Exception {
    //Logic

}

Здесь я хочу убедиться, что передаваемый параметр не содержит никаких Xss или как я могу убедиться, что кодировщик HTML будет работать для моей модели ввода

заранее спасибо


person Anup Deshpande    schedule 27.01.2016    source источник


Ответы (1)


Используйте аннотацию @SafeHtml Hibernate Validator:

https://docs.jboss.org/hibernate/validator/5.2/reference/en-US/html/ch02.html#validator-defineconstraints-hv-constraints

Вам нужно добавить jsoup в качестве зависимости

Пример:

@Entity 
public class Foo {

  @SafeHtml(...)
  private String firstName;

}

Затем, если вы подтвердите сущность, она будет недействительной, если firstName содержит xss

person Neil McGuigan    schedule 27.01.2016