java 个人存储服务_JavaWeb结合七牛云存储搭建个人相册服务

2023-10-14 00:10

本文主要是介绍java 个人存储服务_JavaWeb结合七牛云存储搭建个人相册服务,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、引言

1. 课程概述

相信很多人都知道网站一般会有很多图片,对于小型网站来说,图片放在网站服务器上不算什么,但当图片数量很大时,会造成服务器很臃肿,相应地对带宽要求也会提高,这就造成了成本的增加。其实现在已经流行云存储,我们可以把图片、大文件等放到第三方提供的云存储服务上,这会减少一部分成本。这门课程就介绍了JavaWeb结合七牛云存储来搭建个人相册服务。

2. 预备知识

掌握Servlet+JSP,能了解Bootstrap更好。

二、Just Do It!

项目开始前,你需要有一个七牛云存储的标准用户账号,新建一个Bucket,知道你自己的Access Key和Secret Key。

1. 创建数据库

这里我们使用MySQL数据库,创建名称为photo的数据库:

create database photo DEFAULT CHARSET=utf8;

CREATE TABLE `image` (

`id`int(11) NOT NULL AUTO_INCREMENT,

`name` varchar(16) DEFAULT NULL,

`url` varchar(255) DEFAULT NULL,

`date` datetime DEFAULT NULL,

`user_id`int(11) DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

CREATE TABLE `user` (

`id`int(11) NOT NULL AUTO_INCREMENT,

`username` varchar(16) DEFAULT NULL,

`password` varchar(16) DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

2. 创建JavaWeb项目

这里使用Eclipse创建一个名称为Photo的动态Web项目,加入Tomcat 7服务器,加入所需的jar包(源码中包含jar包),把Photo项目部署到Tomcat上。

3. 编写前端代码

前端使用Bootsrap,把css、fonts和js文件夹放到WebContent目录下。

创建index.jsp:

实验楼个人相册

实验楼个人相册

注册成功

用户名

密码

登录

注册

$('#login').click(function() {//提交登录表单

$.post('${pageContext.request.contextPath}' + '/UserAction?type=1',

{

username: $('#username').val(),

password: $('#password').val()

},

function(data, status) {if (data == '1') {

createPopOver('#username', 'right', '用户名不能为空', 'show');

}else if (data == '2') {

createPopOver('#password', 'right', '密码不能为空', 'show');

}else if (data == '3') {

createPopOver('#username', 'right', '用户名不存在', 'show');

}else if (data == '4') {

createPopOver('#password', 'right', '密码错误', 'show');

}else if (data == 5) {

location.href= '${pageContext.request.contextPath}' + '/home.jsp';

}

});

});//点击注册按钮

$('#register').click(function() {//提交注册表单

$.post('${pageContext.request.contextPath}' + '/UserAction?type=2',

{

username: $('#reg_username').val(),

password: $('#reg_password').val(),

repassword: $('#reg_repassword').val()

},

function(data, status) {if (data == '1') {

createPopOver('#reg_username', 'right', '不能为空', 'show');

}else if (data == '2') {

createPopOver('#reg_password', 'right', '不能为空', 'show');

}else if (data == '3') {

createPopOver('#reg_repassword', 'right', '不能为空', 'show');

}else if (data == '4') {

createPopOver('#reg_repassword', 'right', '密码不一致', 'show');

}else if (data == '5') {

createPopOver('#reg_username', 'right', '用户名已存在', 'show');

}else if (data == '6') {

$('#reg_username').val('');

$('#reg_password').val('');

$('#reg_repassword').val('');

$('#myModal').modal('hide');

$('#alert1').removeClass('hide');

$('#form').css('margin-top', '0px');

}

});

});//显示弹出框

function createPopOver(id, placement, content, action) {

$(id).popover({

placement: placement,

content: content

});

$(id).popover(action);

}//点击输入框时销毁弹出框

$('#username').click(function() {

$('#username').popover('destroy');

});

$('#password').click(function() {

$('#password').popover('destroy');

});

$('#reg_username').click(function() {

$('#reg_username').popover('destroy');

});

$('#reg_password').click(function() {

$('#reg_password').popover('destroy');

});

$('#reg_repassword').click(function() {

$('#reg_repassword').popover('destroy');

});

});

创建home.jsp:

${user.username}的个人相册

操作

%24%7Bimage.url%7D

${image.name }

%24%7Bimage.url%7D

${image.name }

%24%7Bimage.url%7D

${image.name }

这篇关于java 个人存储服务_JavaWeb结合七牛云存储搭建个人相册服务的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/206813

相关文章

SpringBoot实现RSA+AES自动接口解密的实战指南

《SpringBoot实现RSA+AES自动接口解密的实战指南》在当今数据泄露频发的网络环境中,接口安全已成为开发者不可忽视的核心议题,RSA+AES混合加密方案因其安全性高、性能优越而被广泛采用,本... 目录一、项目依赖与环境准备1.1 Maven依赖配置1.2 密钥生成与配置二、加密工具类实现2.1

Nginx进行平滑升级的实战指南(不中断服务版本更新)

《Nginx进行平滑升级的实战指南(不中断服务版本更新)》Nginx的平滑升级(也称为热升级)是一种在不停止服务的情况下更新Nginx版本或添加模块的方法,这种升级方式确保了服务的高可用性,避免了因升... 目录一.下载并编译新版Nginx1.下载解压2.编译二.替换可执行文件,并平滑升级1.替换可执行文件

在Java中实现线程之间的数据共享的几种方式总结

《在Java中实现线程之间的数据共享的几种方式总结》在Java中实现线程间数据共享是并发编程的核心需求,但需要谨慎处理同步问题以避免竞态条件,本文通过代码示例给大家介绍了几种主要实现方式及其最佳实践,... 目录1. 共享变量与同步机制2. 轻量级通信机制3. 线程安全容器4. 线程局部变量(ThreadL

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.