Grails 2.4.4 上的导出插件
Export plugin on Grails 2.4.4
我想制作一个可以上传 Excel 并阅读它们的应用程序。并即时创建 PDF、Excel 和 Word。我使用 Grails 2.4.4。和导出 v 1.6。
这是我的代码
class AuthUserController {
def exportService
def grailsApplication
....
def list = {
if(!params.max) params.max = 10
if(params?.format && params.format != "html"){
response.contentType = grailsApplication.config.grails.mime.types[params.format]
response.setHeader("Content-disposition", "attachment; filename=AuthUser.${params.extension}")
List fields = ["username", "email"]
Map labels = ["username": "username", "email": "email"]
/* Formatter closure in previous releases
def upperCase = { value ->
return value.toUpperCase()
}
*/
// Formatter closure
def upperCase = { domain, value ->
return value.toUpperCase()
}
Map formatters = [username: upperCase]
Map parameters = [username: "admin", "column.widths": [0.2, 0.3, 0.5]]
exportService.export(params.format, response.outputStream, response.outputStream,AuthUser.list(params), [:], fields, labels, formatters, parameters)
}
[ authUserInstanceList: AuthUser.list( params ) ]
}
和模特
class AuthUser {
transient springSecurityService
String username
String password
String email
boolean enabled = true
boolean accountExpired
boolean accountLocked
boolean passwordExpired
static transients = ['springSecurityService']
static hasMany = [madeBillings:Billing, goodsBillings:GoodsBill, approvedRequest:TenantRequest, journals:Journal]
static constraints = {
username blank: false, unique: true
password blank: false
email blank: false, unique: true, email: true
}
static mapping = {
password column: '`password`'
tablePerHierarchy false
}
Set<AuthRole> getAuthorities() {
AuthUserAuthRole.findAllByAuthUser(this).collect { it.authRole }
}
def beforeInsert() {
encodePassword()
}
def beforeUpdate() {
if (isDirty('password')) {
encodePassword()
}
}
protected void encodePassword() {
password = springSecurityService?.passwordEncoder ? springSecurityService.encodePassword(password) : password
}
String toString() {
username
}
}
我尝试使用http://localhost:8080/myapp/authUser/list?format=csv&extension=csv
我在官方插件页面的文档中找到了解决方案
def list = {
if(!params.max) params.max = 10
if(params?.exportFormat && params.exportFormat != "html"){ //must change to exportFormat cause format is reserved for the default grails format
response.contentType = grailsApplication.config.grails.mime.types[params.exportFormat]
response.setHeader("Content-disposition", "attachment; filename=AuthUser.${params.extension}")
exportService.export(params.exportFormat, response.outputStream,AuthUser.list(params), [:], [:])
}
// [ authUserInstanceList: AuthUser.list( params ) ] you have to comment this or give an else clause since the response already called before
}
您可以使用 grails 导出插件将数据导出到 excel、csv、pdf 等格式。它易于配置和使用。
这里是link:http://grails.org/plugin/export
我想制作一个可以上传 Excel 并阅读它们的应用程序。并即时创建 PDF、Excel 和 Word。我使用 Grails 2.4.4。和导出 v 1.6。
这是我的代码
class AuthUserController {
def exportService
def grailsApplication
....
def list = {
if(!params.max) params.max = 10
if(params?.format && params.format != "html"){
response.contentType = grailsApplication.config.grails.mime.types[params.format]
response.setHeader("Content-disposition", "attachment; filename=AuthUser.${params.extension}")
List fields = ["username", "email"]
Map labels = ["username": "username", "email": "email"]
/* Formatter closure in previous releases
def upperCase = { value ->
return value.toUpperCase()
}
*/
// Formatter closure
def upperCase = { domain, value ->
return value.toUpperCase()
}
Map formatters = [username: upperCase]
Map parameters = [username: "admin", "column.widths": [0.2, 0.3, 0.5]]
exportService.export(params.format, response.outputStream, response.outputStream,AuthUser.list(params), [:], fields, labels, formatters, parameters)
}
[ authUserInstanceList: AuthUser.list( params ) ]
}
和模特
class AuthUser {
transient springSecurityService
String username
String password
String email
boolean enabled = true
boolean accountExpired
boolean accountLocked
boolean passwordExpired
static transients = ['springSecurityService']
static hasMany = [madeBillings:Billing, goodsBillings:GoodsBill, approvedRequest:TenantRequest, journals:Journal]
static constraints = {
username blank: false, unique: true
password blank: false
email blank: false, unique: true, email: true
}
static mapping = {
password column: '`password`'
tablePerHierarchy false
}
Set<AuthRole> getAuthorities() {
AuthUserAuthRole.findAllByAuthUser(this).collect { it.authRole }
}
def beforeInsert() {
encodePassword()
}
def beforeUpdate() {
if (isDirty('password')) {
encodePassword()
}
}
protected void encodePassword() {
password = springSecurityService?.passwordEncoder ? springSecurityService.encodePassword(password) : password
}
String toString() {
username
}
}
我尝试使用http://localhost:8080/myapp/authUser/list?format=csv&extension=csv
我在官方插件页面的文档中找到了解决方案
def list = {
if(!params.max) params.max = 10
if(params?.exportFormat && params.exportFormat != "html"){ //must change to exportFormat cause format is reserved for the default grails format
response.contentType = grailsApplication.config.grails.mime.types[params.exportFormat]
response.setHeader("Content-disposition", "attachment; filename=AuthUser.${params.extension}")
exportService.export(params.exportFormat, response.outputStream,AuthUser.list(params), [:], [:])
}
// [ authUserInstanceList: AuthUser.list( params ) ] you have to comment this or give an else clause since the response already called before
}
您可以使用 grails 导出插件将数据导出到 excel、csv、pdf 等格式。它易于配置和使用。
这里是link:http://grails.org/plugin/export