`
dove19900520
  • 浏览: 597463 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Properties文件的增删改查操作

    博客分类:
  • java
阅读更多

废话没有,直接粘代码

package Util;

import java.io.BufferedWriter;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.util.ArrayList;
import java.util.Enumeration;
import java.util.List;
import java.util.Properties;

public class PropertiesUtil extends Properties {  
  
    private static final long serialVersionUID = 1L;  
  
    private List<Object> keyList = new ArrayList<Object>();  
      
    /** 
     * 默认构造方法 
     */  
    public PropertiesUtil() {  
          
    }  
      
    /** 
     * 从指定路径加载信息到Properties 
     * @param path 
     */  
    public PropertiesUtil(String path) {  
        try {  
            InputStream is = new FileInputStream(path);  
           	this.load(new InputStreamReader(is, "UTF-8"));
        } catch (FileNotFoundException e) {  
            e.printStackTrace();  
            throw new RuntimeException("指定文件不存在!");  
        } catch (IOException e) {  
            e.printStackTrace();  
        }  
    }  
      
    /** 
     * 重写put方法,按照property的存入顺序保存key到keyList,遇到重复的后者将覆盖前者。 
     */  
    @Override  
    public synchronized Object put(Object key, Object value) {  
        this.removeKeyIfExists(key);  
        keyList.add(key);  
        return super.put(key, value);  
    }  
      
  
    /** 
     * 重写remove方法,删除属性时清除keyList中对应的key。 
     */  
    @Override  
    public synchronized Object remove(Object key) {  
        this.removeKeyIfExists(key);  
        return super.remove(key);  
    }  
      
    /** 
     * keyList中存在指定的key时则将其删除 
     */  
    private void removeKeyIfExists(Object key) {  
        keyList.remove(key);  
    }  
      
    /** 
     * 获取Properties中key的有序集合 
     * @return 
     */  
    public List<Object> getKeyList() {  
        return keyList;  
    }  
      
    /** 
     * 保存Properties到指定文件,默认使用UTF-8编码 
     * @param path 指定文件路径 
     */  
    public void store(String path) {  
        this.store(path, "UTF-8");  
    }  
      
    /** 
     * 保存Properties到指定文件,并指定对应存放编码 
     * @param path 指定路径 
     * @param charset 文件编码 
     */  
    public void store(String path, String charset) {
    	
        if (path == null || "".equals(path)) {  
        	throw new RuntimeException("存储路径不能为空!");  
        } 
        
        try {  
            OutputStream os = new FileOutputStream(path);  
            BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(os, charset));  
            this.store(bw, null);  
            bw.close();  
        } catch (FileNotFoundException e) {  
            e.printStackTrace();  
        } catch (IOException e) {  
            e.printStackTrace();  
        } finally {
        	
        }
    }  
  
    /** 
     * 重写keys方法,返回根据keyList适配的Enumeration,且保持HashTable keys()方法的原有语义, 
     * 每次都调用返回一个新的Enumeration对象,且和之前的不产生冲突 
     */  
    @Override  
    public synchronized Enumeration<Object> keys() {  
        return new EnumerationAdapter<Object>(keyList);  
    }  
      
    /** 
     * List到Enumeration的适配器 
     */  
    private class EnumerationAdapter<T> implements Enumeration<T> {  
        private int index = 0;  
        private final List<T> list;  
        private final boolean isEmpty;  
          
        public EnumerationAdapter(List<T> list) {  
            this.list = list;  
            this.isEmpty = list.isEmpty();  
        }  
          
        public boolean hasMoreElements() {  
            //isEmpty的引入是为了更贴近HashTable原有的语义,在HashTable中添加元素前调用其keys()方法获得一个Enumeration的引用,  
            //之后往HashTable中添加数据后,调用之前获取到的Enumeration的hasMoreElements()将返回false,但如果此时重新获取一个  
            //Enumeration的引用,则新Enumeration的hasMoreElements()将返回true,而且之后对HashTable数据的增、删、改都是可以在  
            //nextElement中获取到的。  
            return !isEmpty && index < list.size();  
        }  
  
        public T nextElement() {  
            if (this.hasMoreElements()) {  
                return list.get(index++);  
            }  
            return null;  
        }  
    }  
}  

 

分享到:
评论

相关推荐

    swing 写的与数据库的增删改查操作

    在"Swing写的与数据库的增删改查操作"中,我们探讨的是如何使用Swing来构建用户界面,同时通过Java Database Connectivity (JDBC) API进行数据库的CRUD(Create、Read、Update、Delete)操作。这个项目可能涉及了...

    greenDAO3 项目搭建与增删改查操作

    **greenDAO3 项目搭建与增删改查操作** greenDAO 是一个流行的对象关系映射(ORM)库,专门用于Android平台,它使得在Android应用中处理SQLite数据库变得更加简便。greenDAO3是其第三个主要版本,引入了一些改进和...

    springBoot简单后台增删改查实例

    在本实例中,我们将深入探讨如何使用SpringBoot框架构建一个简单的后台系统,实现数据库的增删改查功能。SpringBoot以其简洁的配置和强大的功能,成为现代Java开发中的热门选择。接下来,我们将按照标题和描述,详细...

    SpringBoot 增删改查实例Demo

    在本实例中,我们将深入探讨如何使用SpringBoot框架进行数据库操作,主要集中在增删改查(CRUD)功能。SpringBoot以其简洁的配置和强大的功能,成为Java开发中广泛采用的框架,尤其在构建微服务时更为突出。下面,...

    springboot增删改查

    本知识点将深入探讨如何利用SpringBoot实现数据库的增删改查操作。 一、SpringBoot入门 SpringBoot的核心理念是“约定优于配置”,它内置了Tomcat服务器,自动配置了Spring MVC、Spring Data JPA等模块,使得开发者...

    页面的增删改查代码-java

    在IT行业中,页面的增删改查(CRUD:Create, Read, Update, Delete)是基本的操作,尤其在Web开发中。这些操作构成了数据管理的核心,无论是在前端展示还是后端处理,都不可或缺。本压缩包文件“页面的增删改查代码-...

    springboot+mybatis+mysql+layUI+thymeleaf实现增删改查

    在本项目中,LayUI用于构建用户界面,提供表格、按钮、表单等元素,使得用户能够直观地进行学生信息的增删改查操作。LayUI的响应式设计也确保了在不同设备上的良好用户体验。 **Thymeleaf** Thymeleaf是一个现代...

    Maven+SpringBoot+JPA单表增删改查实例

    最后,运行项目,通过发送HTTP请求到对应的API端点,即可实现对单表数据的增删改查操作。例如,发送POST请求到`/users`创建新用户,GET请求到`/users`获取所有用户,PUT请求更新指定ID的用户,DELETE请求删除指定ID...

    一套基于SpringBoot+SSM框架的增删改查模板

    - `control`:代表Controller层,这里是处理HTTP请求的Java类,通常会包含对应于增删改查操作的方法。 - `dao`:代表DAO层,包含了与数据库交互的接口和实现类,通常使用MyBatis的SqlSession和Mapper接口进行数据库...

    IDEA搭建SSM实现登录、注册,增删改查功能

    对于增删改查功能,创建对应的CRUD操作页面,如list.html显示所有用户,edit.html用于编辑用户信息,delete.html处理删除请求。在Controller中,根据请求类型调用对应的服务方法。 最后,配置SpringMVC的...

    greendao 实现增删改查功能

    本篇将深入讲解如何利用 greendao 实现增删改查(CRUD:Create, Read, Update, Delete)功能,并基于 `Android Studio` 开发环境进行实践。 1. **安装与配置 greendao** 首先,我们需要在 `build.gradle` 文件中...

    SpringBoot整合MyBatis Plus实现增删改查教程

    本文详细介绍了如何使用 Spring Boot 框架和 MyBatis Plus 实现增删改查操作的教程。MyBatis Plus 提供了许多实用的功能来简化数据库交互,例如自动将 Java 对象与数据库表对应,自动生成 SQL 语句等。

    spring boot mybatis jsp前端展示对mysql增删改查

    在本项目中,我们主要探讨的是如何利用Spring Boot、MyBatis和JSP技术来实现对MySQL数据库的增删改查操作,并通过前端界面展示这些功能。这是一个基础的Web应用程序开发示例,适合初学者用来了解和实践相关技术。...

    Gradle+SpringBoot+JPA单表的增删改查实例

    在本项目中,我们主要探讨的是如何利用Gradle构建工具,SpringBoot框架,以及Java Persistence API(JPA)来实现单表的增删改查功能。这是一个非常适合初学者上手的实例,它将帮助你理解如何在实际开发环境中集成...

    neo4j服务端开发示例,采用spring-boot开发,内含节点增删改查、关系增删改查、复杂关系的查询。

    在本示例中,我们将深入探讨如何利用Spring Boot框架进行Neo4J服务端开发,实现节点与关系的增删改查以及复杂的查询操作。 首先,"neo4j-community-3.5.18-windows.zip"是Neo4j 3.5.18版本的Windows安装文件。这个...

    JEECG 平台实现增删改查以及将项目部署到服务器流程

    在IT行业中,JEECG平台是一个基于代码生成器的Java快速开发框架,它极大地提高了开发效率,特别是对于常见的增删改查(CRUD)操作。本文将深入探讨如何利用JEECG实现这些基本功能,并详细讲解如何将项目部署到服务器...

    Springboot工程整合mybatis增删改查 + swagger

    综上所述,这个项目展示了如何在Spring Boot工程中整合MyBatis进行数据的增删改查操作,以及如何利用Swagger自动生成API文档。这样的集成使得开发更加高效,同时也方便了API的测试和文档分享。通过深入理解和实践...

    利用springboot-jpa实现对数据库的增删改查操作

    本教程将深入讲解如何使用Spring Boot与JPA来实现对MySQL数据库的增删改查(CRUD)操作。 首先,我们需要在项目中引入Spring Boot和JPA的依赖。在`pom.xml`或`build.gradle`文件中添加相关依赖,例如对于Maven项目...

    基于SSM框架的Java企业级增删改查(CRUD)系统源码

    本项目是一个基于SSM(Spring、SpringMVC、MyBatis)框架的Java企业级增删改查(CRUD)系统源码。该系统主要采用Java语言开发,同时整合了CSS、JavaScript等前端技术。 技术构成: - 后端语言:Java - 前端技术:...

    spring boot+react 前后端分离实现增删改查

    在本项目中,MySQL将作为存储数据的媒介,Spring Boot通过JPA或MyBatis与MySQL进行通信,执行SQL语句,完成对数据的增删改查操作。 实现前后端分离的增删改查功能,主要涉及以下步骤: 1. **环境配置**:安装Node....

Global site tag (gtag.js) - Google Analytics