Last updated by admin 3 years ago
??
?????
Grails????????????????????????????"constraints"???????????groovy?builder??????????????????class User {
@Property Long id
@Property Long version @Property String login
@Property String password
@Property String email
@Property Date age @Property constraints = {
login(length:5..15,blank:false,unique:true)
password(length:5..15,blank:false)
email(email:true,blank:false)
age(min:new Date(),nullable:false)
}
}def user = new User() // populate propertiesif(user.validate()) { // do something with user } else { user.errors.allErrors.each { println it } }
if(user.save()) { return user } else { user.errors.allErrors.each { println it } }
????????
?????????????????????????For starters you need to redirect to the right action or view with your erroneous bean:class UserController {
@Property save = {
def u = new User()
u.properties = params
if(u.save()) {
// do something
}
else {
render(view:'create',model:[user:u])
}
}
}chain(action:create,model:[user:u])
<g:hasErrors bean="${user}> <g:renderErrors bean="${user}" as="list" /> </g:hasErrors>
<div class="prop ${hasErrors(bean:user,field:'login', 'errors')}"> <label for="login"><input type="text" name="login" /> </div>
.errors { border: 1px solid red }Changing the Error Message
Of course the default error message that Grails displays is probably not what you were after, so you will want to change this. The way you do this is by modifying the "grails-app/i18n/messages.properties" file and adding a message for the particular error code.For example if we follow the above example the error code may be "user.login.length.tooshort" so we add an entry:user.login.length.tooshort=I'm sorry the login you entered wasn't quite long enough, please make it longerDefining constraints for Hibernate mapped classes
To integrate with the Grails constraints mechanism and hence hook into useful things like the way the views are generated and Grails' Validation mechanism you can do so by creating a Groovy script following the naming convention of your domain class and ending in the "Constraints" suffix. For example for a "com.books.HibernateBook" class (either an EJB3 entity of mapped with Hibernate XML) defined above you would need to create a "com/books/HibernateBookConstraints.groovy" script in the same package is the class itself. Within the script just define constraints in the same way as you would do in a GORM class but without the @Property notation:constraints = {
title(length:5..15)
desc(blank:false)
}


