No Description

shentar 21d68480e1 bug fixes. 1 month ago
dedup 44dc62b021 update 5 months ago
jdbcsqlitenative 0787e1c4ca remove unwanted files. 2 years ago
photoweb 21d68480e1 bug fixes. 1 month ago
scripts 87cce8b974 update readme.txt 4 months ago
.gitignore 27299caf8e format XML. 11 months ago
.travis.yml 8f87785cc2 add jdk9 compile support. 6 months ago 8e317b5cde update 4 months ago
ReleaseNotes.txt 4da0f87fa6 update ReleaseNotes.txt. 4 months ago
asmblefiles.xml e1a2d3aa43 bug fixes. 8 months ago
build.xml 81ec713d23 add HTTPS supported. 8 months ago
build_for_Raspberry3.xml 81ec713d23 add HTTPS supported. 8 months ago
pom.xml d7f54caddc renew version number. 6 months ago
pom_for_Raspberry3.xml 27299caf8e format XML. 11 months ago


Build Status

这是一个使用Java语言编写的本地照片管理系统。使用BS架构。服务端采用Servlet提供RESTful风格接口和动态页面供浏览器直接访问,集成照片Exif信息处理、视频流信息处理和人像识别等技术,集成本地和Amazon S3云存储同步备份功能。服务端提供后台任务扫描指定目录,并收集指定后缀名的照片文件,生成照片库,识别照片HASH指纹、长宽比、拍摄时间等,最终按照拍摄时间生成年、月、日、人像归集的归档页面,并根据配置信息将数据保存到远端云存储上面(S3)。对于重复照片只会显示一份。相册界面可自适应兼容桌面操作系统浏览器和移动操作系统浏览器。项目主页:主页

This is a local photo management system written with the Java language. Using B/S architecture. The server uses Servlet to provide RESTful style interface and dynamic page for direct access to the web browser, integrated photos Exif information processing, video stream information processing and face recognition technology, integrated local and Amazon S3 cloud storage synchronous backup function. Service provides a background task scans the specified directory, and collect the specified suffix photos, then generate a photo gallery. HASH fingerprint is used to recognize the duplicate pic fils. The shooting time in Exif is used to sort all the files. By identifying the picture's aspect ratio, set the appropriate display size on a Web page. Eventually in time axis to generate a year, month, and day dimensions page. HomePage of jAlbum:HomePage


For ARM platform, such as Raspberry3 ubuntu-mate system, compile jdbcsqlite native so first. Other platform may not need this.

cd jAlbum
mvn install -f pom_for_Raspberry3.xml

For other platforms, such as Windows, X86 Linux etc. just run the command like:

cd jAlbum
mvn install 

The build target files are store in the jAlbum/distribute folder.

You can also get the release package in this web page: jAlbum release


0. Configure the jalbum.xml file.

cd jAlbum/distribute
edit the jalbum.xml

<?xml version="1.0" encoding="utf-8" ?>  
        <dir>C:\\Program Files\\</dir>

picfilesuffix the file type with the suffix that can be scaned by the tool. It is case-insensitive. If the "mp4" suffix is configured, You must make sure there is ffprobe exe command in the server. See FFmpeg. for details.
inputdir specify the folder which need to scan.
excludedir specify the folder which you do not like the tool scan and display the content of it.
minfilesize specify the min size of Pic file in byte.
maxfilesize specify the max size of Pic file in byte.
maxpicsperonepage specify the max pic count of one index page.

threadcount specify the size of thread pool.
hashalog specify the file HASH fingerprint Algorithm. The common algorithms are: SHA-256, MD5, SHA-1. You can find the stand algorithm names in MessageDigest Algorithms.
accessAuth specifie whether public access is allowed.
GoogleAnalyticsID specifie the Google Analytics service ID to track all the internet accesses.
thumbnaildir specify the folder which to store the thumbnail to.
s3 specify the Amazon S3 backup info such as bucketname, ak, sk and useHttps.
HuaweiOBS specify the Huawei Cloud OBS backup info such as access endpoint, bucketname, ak, sk and useHttps.
Facer specify the face++ service API info, such as ak, sk and custom facesetprefix.

1. Start the tool

For the ARM platforms like Raspberry3 ubuntu-mate system:

cd jAlbum/distribute

For other linux platforms:

cd jAlbum/distribute

For Windows platforms:

cd jAlbum/distribute


Open the url: http://ip:2148/ in any Web Browser to access the photo album. After you enable access authentication, you need to get the token before you can access it. In the local host of jAlbum running in, visit the following address can manage the token:
1), get the token generated by the server.
2), clear all the current token.
3)${token}, clear the specified token, and generate a new token.

Login with superToken, allowing you to hide photos or videos, normal tokens can only view the album.


jAlbum Screenshot