⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 populateddatabase.java

📁 acegi构造安全的java系统
💻 JAVA
字号:
/* Copyright 2004, 2005, 2006 Acegi Technology Pty Limited * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * *     http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */package org.acegisecurity;import org.springframework.jdbc.core.JdbcTemplate;import org.springframework.jdbc.datasource.DriverManagerDataSource;import javax.sql.DataSource;/** * Singleton which provides a populated database connection for all JDBC-related unit tests. * * @author Ben Alex * @version $Id: PopulatedDatabase.java 1496 2006-05-23 13:38:33Z benalex $ */public class PopulatedDatabase {    //~ Static fields/initializers =====================================================================================    private static DriverManagerDataSource dataSource = null;    //~ Constructors ===================================================================================================    private PopulatedDatabase() {}    //~ Methods ========================================================================================================    public static DataSource getDataSource() {        if (dataSource == null) {            setupDataSource();        }        return dataSource;    }    private static void setupDataSource() {        dataSource = new DriverManagerDataSource();        dataSource.setDriverClassName("org.hsqldb.jdbcDriver");        dataSource.setUrl("jdbc:hsqldb:mem:acegisecuritytest");        dataSource.setUsername("sa");        dataSource.setPassword("");        JdbcTemplate template = new JdbcTemplate(dataSource);        template.execute(            "CREATE TABLE USERS(USERNAME VARCHAR_IGNORECASE(50) NOT NULL PRIMARY KEY,PASSWORD VARCHAR_IGNORECASE(50) NOT NULL,ENABLED BOOLEAN NOT NULL)");        template.execute(            "CREATE TABLE AUTHORITIES(USERNAME VARCHAR_IGNORECASE(50) NOT NULL,AUTHORITY VARCHAR_IGNORECASE(50) NOT NULL,CONSTRAINT FK_AUTHORITIES_USERS FOREIGN KEY(USERNAME) REFERENCES USERS(USERNAME))");        template.execute("CREATE UNIQUE INDEX IX_AUTH_USERNAME ON AUTHORITIES(USERNAME,AUTHORITY)");        template.execute(            "CREATE TABLE ACL_OBJECT_IDENTITY(ID BIGINT GENERATED BY DEFAULT AS IDENTITY(START WITH 0)  NOT NULL PRIMARY KEY,OBJECT_IDENTITY VARCHAR_IGNORECASE(250) NOT NULL,PARENT_OBJECT BIGINT,ACL_CLASS VARCHAR_IGNORECASE(250) NOT NULL,CONSTRAINT UNIQUE_OBJECT_IDENTITY UNIQUE(OBJECT_IDENTITY),CONSTRAINT SYS_FK_3 FOREIGN KEY(PARENT_OBJECT) REFERENCES ACL_OBJECT_IDENTITY(ID))");        template.execute(            "CREATE TABLE ACL_PERMISSION(ID BIGINT GENERATED BY DEFAULT AS IDENTITY(START WITH 0)  NOT NULL PRIMARY KEY,ACL_OBJECT_IDENTITY BIGINT NOT NULL,RECIPIENT VARCHAR_IGNORECASE(100) NOT NULL,MASK INTEGER NOT NULL,CONSTRAINT UNIQUE_RECIPIENT UNIQUE(ACL_OBJECT_IDENTITY,RECIPIENT),CONSTRAINT SYS_FK_7 FOREIGN KEY(ACL_OBJECT_IDENTITY) REFERENCES ACL_OBJECT_IDENTITY(ID))");        template.execute("SET IGNORECASE TRUE");        template.execute("INSERT INTO USERS VALUES('dianne','emu',TRUE)");        template.execute("INSERT INTO USERS VALUES('marissa','koala',TRUE)");        template.execute("INSERT INTO USERS VALUES('peter','opal',FALSE)");        template.execute("INSERT INTO USERS VALUES('scott','wombat',TRUE)");        template.execute("INSERT INTO USERS VALUES('cooper','kookaburra',TRUE)");        template.execute("INSERT INTO AUTHORITIES VALUES('marissa','ROLE_TELLER')");        template.execute("INSERT INTO AUTHORITIES VALUES('marissa','ROLE_SUPERVISOR')");        template.execute("INSERT INTO AUTHORITIES VALUES('dianne','ROLE_TELLER')");        template.execute("INSERT INTO AUTHORITIES VALUES('scott','ROLE_TELLER')");        template.execute("INSERT INTO AUTHORITIES VALUES('peter','ROLE_TELLER')");        template.execute(            "INSERT INTO acl_object_identity VALUES (1, 'org.acegisecurity.acl.DomainObject:1', null, 'org.acegisecurity.acl.basic.SimpleAclEntry');");        template.execute(            "INSERT INTO acl_object_identity VALUES (2, 'org.acegisecurity.acl.DomainObject:2', 1, 'org.acegisecurity.acl.basic.SimpleAclEntry');");        template.execute(            "INSERT INTO acl_object_identity VALUES (3, 'org.acegisecurity.acl.DomainObject:3', 1, 'org.acegisecurity.acl.basic.SimpleAclEntry');");        template.execute(            "INSERT INTO acl_object_identity VALUES (4, 'org.acegisecurity.acl.DomainObject:4', 1, 'org.acegisecurity.acl.basic.SimpleAclEntry');");        template.execute(            "INSERT INTO acl_object_identity VALUES (5, 'org.acegisecurity.acl.DomainObject:5', 3, 'org.acegisecurity.acl.basic.SimpleAclEntry');");        template.execute(            "INSERT INTO acl_object_identity VALUES (6, 'org.acegisecurity.acl.DomainObject:6', 3, 'org.acegisecurity.acl.basic.SimpleAclEntry');");        // ----- BEGIN deviation from normal sample data load script -----        template.execute(            "INSERT INTO acl_object_identity VALUES (7, 'org.acegisecurity.acl.DomainObject:7', 3, 'some.invalid.acl.entry.class');");        // ----- FINISH deviation from normal sample data load script -----        template.execute("INSERT INTO acl_permission VALUES (null, 1, 'ROLE_SUPERVISOR', 1);");        template.execute("INSERT INTO acl_permission VALUES (null, 2, 'ROLE_SUPERVISOR', 0);");        template.execute("INSERT INTO acl_permission VALUES (null, 2, 'marissa', 2);");        template.execute("INSERT INTO acl_permission VALUES (null, 3, 'scott', 14);");        template.execute("INSERT INTO acl_permission VALUES (null, 6, 'scott', 1);");    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -