在Grails中创建一个简单的Twitter应用程序(第1部分)(2.3.2版本实践)

mrice00 2013-11-24

本文是按照网上已有的案例来的:

http://blog.csdn.net/laoxue6699/article/details/9722111

但网上这个案例是2.0版本 并不适用2.3.2 实际上文中说的安装插件等命令在2.3.2中已经被弃用了

而且很多配置也产生较大的变化

具体过程和上面所给网址一样 本人也是刚刚接触grails 具体学习的资源就是官网的manual和stackoverflow中有关grails的问题等

如有错误 欢迎纠正

在安装好grails后 运行以下指令新建一个项目:

grails create-app simple-twitter  //在当前目录新建一个项目
cd simple-twitter //进入项目根目录

安装插件的方式已经改变了

现在的方式在grails-app/conf/buildConfig.groovy

在plugins下加入

compile ":spring-security-core:2.0-RC2"//不知道定位的先用 grails install-plugin spring-security-core 这个命令本身不会安装插件了 但会有相关安装插件的提示

 这样还不行 还得加入一个spring的repo

在repositories下加入:

mavenRepo 'http://repo.spring.io/milestone'

 好 先展现一下buildConfig.groovy的样子:

grails.servlet.version = "3.0" // Change depending on target container compliance (2.5 or 3.0)
grails.project.class.dir = "target/classes"
grails.project.test.class.dir = "target/test-classes"
grails.project.test.reports.dir = "target/test-reports"
grails.project.work.dir = "target/work"
grails.project.target.level = 1.6
grails.project.source.level = 1.6
//grails.project.war.file = "target/${appName}-${appVersion}.war"

/*
grails.project.fork = [
    // configure settings for compilation JVM, note that if you alter the Groovy version forked compilation is required
    //  compile: [maxMemory: 256, minMemory: 64, debug: false, maxPerm: 256, daemon:true],

    // configure settings for the test-app JVM, uses the daemon by default
    test: [maxMemory: 768, minMemory: 64, debug: false, maxPerm: 256, daemon:true],
    // configure settings for the run-app JVM
    run: [maxMemory: 768, minMemory: 64, debug: false, maxPerm: 256, forkReserve:false],
    // configure settings for the run-war JVM
    war: [maxMemory: 768, minMemory: 64, debug: false, maxPerm: 256, forkReserve:false],
    // configure settings for the Console UI JVM
    console: [maxMemory: 768, minMemory: 64, debug: false, maxPerm: 256]
]
*/

grails.project.dependency.resolver = "maven" // or ivy
grails.project.dependency.resolution = {
    // inherit Grails' default dependencies
    inherits("global") {
        // specify dependency exclusions here; for example, uncomment this to disable ehcache:
        // excludes 'ehcache'
    }
    log "error" // log level of Ivy resolver, either 'error', 'warn', 'info', 'debug' or 'verbose'
    checksums true // Whether to verify checksums on resolve
    legacyResolve false // whether to do a secondary resolve on plugin installation, not advised and here for backwards compatibility

    repositories {
        inherits true // Whether to inherit repository definitions from plugins

        grailsPlugins()
        grailsHome()
        mavenLocal()
        grailsCentral()
        mavenCentral()
        // uncomment these (or add new ones) to enable remote dependency resolution from public Maven repositories
        //mavenRepo "http://repository.codehaus.org"
        //mavenRepo "http://download.java.net/maven/2/"
        //mavenRepo "http://repository.jboss.com/maven2/"
		mavenRepo 'http://repo.spring.io/milestone' //spring的仓库
    }

    dependencies {
        // specify dependencies here under either 'build', 'compile', 'runtime', 'test' or 'provided' scopes e.g.
        // runtime 'mysql:mysql-connector-java:5.1.24'
		runtime 'mysql:mysql-connector-java:5.1.21' //这个是加mysql的依赖要用的话先把这个jar包放在根目录下的lib目录下
    }

    plugins {
        // plugins for the build system only
        build ":tomcat:7.0.42"

        // plugins for the compile step
        compile ":scaffolding:2.0.1"
        compile ':cache:1.1.1'
		compile ":spring-security-core:2.0-RC2" //这个是新增的

        // plugins needed at runtime but not for compilation
        runtime ":hibernate:3.6.10.3" // or ":hibernate4:4.1.11.2"
        runtime ":database-migration:1.3.8"
        runtime ":jquery:1.10.2"
        runtime ":resources:1.2.1"
        // Uncomment these (or add new ones) to enable additional resources capabilities
        //runtime ":zipped-resources:1.0.1"
        //runtime ":cached-resources:1.1"
        //runtime ":yui-minify-resources:0.1.5"
    }
}

接下来执行下

grails compile

然后就可以用s2-quickstart等命令了

grails s2-quickstart org.grails.twitter(这个是包名) Person Authority

 这样会在domain下产生三个领域对象

与链接中的文章不同 要在bootstrap中进行插入操作 必须使用事务:

import org.cc.twitter.*

class BootStrap {

    def init = { servletContext ->
         if (!Person.count()) {
            createData()
        }
    }
    def destroy = {
    }
	
   private void createData() {
   
    def userRole=null
    Authority.withTransaction{
      userRole = new Authority(authority: 'ROLE_USER').save()
	}
	/* The default password for all user. No need to encode here to avoid double encoding. */
	String password = 'password'
	Person.withTransaction{
	[yancy: 'Yancy Vance Paredes', john: 'John Doe', jane: 'Jane Smith'].each { userName, realname ->
		def user = new Person(username: userName, realname: realname, password: password, enabled: true).save()
		PersonAuthority.create user, userRole, true
	}
	}
}
}

接下去用grails run-app 或者run-app(交互模式下)

没问题的话 就可以看到界面了

但此时的logout那个链接点进去是405(不能使用get方法来logout) 这是spring-security-core 2中默认的

要改变规则在 config.groovy中加入:

grails.plugin.springsecurity.logout.postOnly = false

 然后stop-app再run-app 如果还不行 那么把交互模式关掉 再进去 我在这个步骤里 试了下用clean 结果再run-app的时候出现一堆错误 但是重新打开再进去 就完全没有问题了...

附:

1、如果执行run-app的操作 出现fork错误

那么把BuildConfig.groovy中的grails.project.fork给注释掉

2、在datasource.groovy中增加mysql支持:

dataSource {
    pooled = true
    driverClassName = "org.h2.Driver"
    username = "sa"
    password = ""
}

dataSource_mysql { 
	dialect = org.hibernate.dialect.MySQLDialect 
	driverClassName = 'com.mysql.jdbc.Driver' 
	username = 'root' 
	password = '' 
	url = 'jdbc:mysql://localhost:3306/grails_twitter' 
	dbCreate = 'update'  //只更新 不创建 
} 

hibernate {
    cache.use_second_level_cache = true
    cache.use_query_cache = false
    cache.region.factory_class = 'net.sf.ehcache.hibernate.EhCacheRegionFactory' // Hibernate 3
//    cache.region.factory_class = 'org.hibernate.cache.ehcache.EhCacheRegionFactory' // Hibernate 4
}

// environment specific settings
environments {
    development {
        dataSource {
            dbCreate = "create-drop" // one of 'create', 'create-drop', 'update', 'validate', ''
            url = "jdbc:h2:mem:devDb;MVCC=TRUE;LOCK_TIMEOUT=10000;DB_CLOSE_ON_EXIT=FALSE"
        }
    }
    test {
        dataSource {
            dbCreate = "update"
            url = "jdbc:h2:mem:testDb;MVCC=TRUE;LOCK_TIMEOUT=10000;DB_CLOSE_ON_EXIT=FALSE"
        }
    }
    production {
        dataSource {
            dbCreate = "update"
            url = "jdbc:h2:prodDb;MVCC=TRUE;LOCK_TIMEOUT=10000;DB_CLOSE_ON_EXIT=FALSE"
            properties {
               maxActive = -1
               minEvictableIdleTimeMillis=1800000
               timeBetweenEvictionRunsMillis=1800000
               numTestsPerEvictionRun=3
               testOnBorrow=true
               testWhileIdle=true
               testOnReturn=false
               validationQuery="SELECT 1"
               jdbcInterceptors="ConnectionState"
            }
        }
    }
}

 要是用mysql

只需在domain中加入

static mapping={
  datasource 'mysql'  
  //mapping还支持修改表明 修改列名等操作
  /*
  table '表名'
    columns {
      属性名 column:'列名'
    }
  */
}

相关推荐