首页
关于这个博客
Search
1
Java 实现Google 账号单点登录(OAuth 2.0)全流程解析
231 阅读
2
Spring AI 无法获取大模型深度思考内容?解决方案来了
201 阅读
3
微信小程序实现页面返回前确认弹窗:兼容左上角返回与右滑返回
91 阅读
4
服务器遭遇 XMRig 挖矿程序入侵排查与清理全记录
66 阅读
5
解决 Mac 版 PicGo 无法打开问题:“已损坏,无法打开” 报错处理指南
37 阅读
Java 核心
框架与中间件
数据库技术
开发工具与效率
问题排查与踩坑记录
程序员成长与思考
前端
登录
Search
标签搜索
java虚拟机
JVM
保姆级教程
Java
Spring AI
SpringBoot
Nginx
WebFlux
Spring
cdn
https
dcdn
网站加速
Tool
图片导出
服务部署
源码解析
单点登录
google
sso
Luca Ju
累计撰写
35
篇文章
累计收到
1
条评论
首页
栏目
Java 核心
框架与中间件
数据库技术
开发工具与效率
问题排查与踩坑记录
程序员成长与思考
前端
页面
关于这个博客
搜索到
4
篇与
的结果
2025-08-18
从零开始:Java 服务部署与 HTTPS 访问全攻略
前言在现代 Web 应用开发中,将 Java 服务部署到服务器并通过 HTTPS 安全访问是一项基础且重要的技能。本文将详细记录从环境准备到最终实现 HTTPS 访问的完整过程,适合新手开发者参考学习。一、JDK 环境安装Java 服务运行依赖 JDK 环境,我们选择安装开源免费的 OpenJDK 17 版本。1. 更新系统索引包首先需要更新 Ubuntu 系统的软件包索引,确保能获取到最新的软件版本信息:sudo apt update2. 安装 OpenJDK 17执行以下命令安装 OpenJDK 17:sudo apt install openjdk-17-jdk安装过程中系统会自动处理依赖关系,无需额外操作。3. 验证 JDK 安装结果安装完成后,通过以下命令验证是否安装成功:java -version如果安装成功,会显示类似如下的版本信息:openjdk version "17.0.x" 20xx-xx-xx OpenJDK Runtime Environment (build 17.0.x+xx-Ubuntu-1ubuntux) OpenJDK 64-Bit Server VM (build 17.0.x+xx-Ubuntu-1ubuntux, mixed mode, sharing)4. 配置 JAVA_HOME 环境变量为了让系统和其他工具能正确识别 JDK 位置,需要配置 JAVA_HOME 环境变量:echo "export JAVA_HOME=/usr/lib/jvm/java-17-openjdk-amd64" >> ~/.bashrc source ~/.bashrc执行完成后,JAVA_HOME 环境变量将在每次登录时自动生效。二、Java 服务打包与部署完成 JDK 环境配置后,接下来需要将开发好的 Java 服务打包并上传到服务器。1. 服务打包使用 Maven 工具对 Java 项目进行打包,推荐通过 IDEA 的 Maven 插件操作:在 IDEA 右侧的 Maven 面板中找到项目展开 Lifecycle 选项双击 package 命令执行打包操作打包成功后,会在项目的 target 目录下生成对应的 JAR 文件2. 上传服务到服务器将打包好的 JAR 文件通过 SFTP 工具(如 Termius)或 scp 命令上传到服务器的指定目录,例如/opt/java/services/目录。3. 启动 Java 服务通过以下命令启动 Java 服务:nohup java -jar /opt/java/services/your-service.jar &其中&符号表示让服务在后台运行。如果需要更完善的服务管理,建议配置 systemd 服务。三、Nginx 配置实现 HTTPS 访问为了实现 HTTPS 访问并优化请求转发,我们需要配置 Nginx 作为反向代理服务器。1. 创建或编辑 Nginx 配置文件执行以下命令创建新的 Nginx 配置文件:sudo nano /etc/nginx/sites-available/your_domain.conf如果你已有配置文件,直接编辑对应文件即可。2. 配置 HTTPS 与反向代理在配置文件中添加以下内容,实现 HTTP 到 HTTPS 的跳转以及请求转发:server { listen 80; server_name yourdomain.com; # 替换为你的实际域名 # 将所有HTTP请求强制跳转至HTTPS return 301 https://$host$request_uri; } server { listen 443 ssl; server_name yourdomain.com; # 替换为你的实际域名 # SSL证书配置(请替换为你的证书实际路径) ssl_certificate /etc/letsencrypt/live/yourdomain.com/fullchain.pem; ssl_certificate_key /etc/letsencrypt/live/yourdomain.com/privkey.pem; # SSL安全优化配置 ssl_protocols TLSv1.2 TLSv1.3; # 支持的TLS协议版本 ssl_prefer_server_ciphers on; ssl_ciphers "EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH"; ssl_session_cache shared:SSL:10m; # SSL会话缓存设置 ssl_session_timeout 10m; # SSL会话超时时间 # 将所有 /app 开头的请求转发到Java服务的9999端口 location /app/ { proxy_pass http://127.0.0.1:9999; # 传递原始请求信息(HTTPS环境关键配置) proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; # 重要:传递HTTPS协议信息 # 超时设置(根据实际服务需求调整) proxy_connect_timeout 300s; proxy_read_timeout 300s; } # 其他路径处理 location / { # 可以根据需求配置为返回404或指向其他服务 return 404; } }3. 启用 Nginx 配置创建符号链接将配置文件添加到 sites-enabled 目录,使 Nginx 能够识别该配置:sudo ln -s /etc/nginx/sites-available/your_domain.conf /etc/nginx/sites-enabled/4. 检查并重启 Nginx配置完成后,先检查配置文件是否有语法错误:sudo nginx -t如果显示 "nginx: configuration file /etc/nginx/nginx.conf test is successful",说明配置无误,可以重启 Nginx 使配置生效:sudo systemctl restart nginx四、验证 HTTPS 访问完成以上所有步骤后,通过浏览器访问https://yourdomain.com/app/user/login(替换为你的实际域名和接口路径),如果能正常访问并获得服务响应,说明整个部署过程成功完成。常见问题排查如果无法访问 HTTPS 服务,先检查服务器防火墙是否开放 443 端口证书路径错误会导致 Nginx 启动失败,需确保证书文件存在且权限正确Java 服务未启动或端口被占用会导致 502 错误,可通过netstat -tlnp查看端口占用情况配置文件修改后未重启 Nginx 会导致配置不生效,记得每次修改后重启服务通过本文的步骤,你已经成功实现了 Java 服务的部署和 HTTPS 访问配置。在实际生产环境中,还可以根据需求添加服务监控、日志管理等功能,进一步提升服务的稳定性和可维护性。
2025年08月18日
16 阅读
0 评论
0 点赞
2025-08-15
个人博客提交搜索引擎收录的保姆级教程
前言搭建完个人博客后,持续输出优质内容的同时,让博客被搜索引擎收录是提升曝光的关键。本文以 Google、Baidu、Bing 为例,手把手教你完成收录提交,其他搜索引擎可举一反三~一、Google 收录:最快见效的全球引擎Google 是全球影响力最大的搜索引擎,收录速度快且覆盖范围广,优先推荐配置。1. 登录 Google 站长平台访问 Google 搜索控制台,点击 “添加属性”,选择 “网址前缀”,输入你的博客完整地址(如 https://www.lucaju.cn)。2. 网站验证:证明你是网站主人选择 “HTML 文件上传” 验证方式,下载 Google 提供的验证文件(如 google123456.html)。将文件上传至博客根目录(以 Typecho 为例,上传到Typecho的安装路径下)。点击 “验证” 按钮,提示成功即完成验证。3. 提交 Sitemap:引导搜索引擎抓取什么是 Sitemap?Sitemap(网站地图)是包含网站所有页面链接的 XML 文件,帮助搜索引擎快速了解网站结构,提升抓取效率。(1)生成 SitemapTypecho 博客:安装 Sitemap 插件,启用后自动在根目录生成 sitemap.xml(访问 https://你的域名/sitemap.xml 可查看)。其他建站工具:搜索对应平台的 Sitemap 插件(如 WordPress 直接安装 Yoast SEO 插件)。(2)提交 Sitemap 到 Google在 Google 搜索控制台左侧菜单选择 “sitemaps”,输入 sitemap.xml 并提交,等待 Google 解析抓取。4. 验证收录结果提交后约 1-2 小时(Google 收录速度极快),可通过 Google 搜索 site:你的域名(如 site:lucaju.cn)验证是否收录。二、Baidu 收录:聚焦中文用户百度是国内主流搜索引擎,流程与 Google 类似,但需注意细节差异。1. 登录百度搜索资源平台访问 百度搜索资源平台,注册并登录后,点击 “添加网站”,输入博客域名。2. 网站验证与类型选择选择网站类型验证方式推荐 “HTML 文件验证”,步骤同 Google(下载验证文件并上传至根目录)3. 内容提交:替代 Sitemap 的方案目前百度对 Sitemap.xml 支持有限,可通过以下方式提交内容:手动提交:在 “链接提交” 页面逐条输入新文章 URL。API 提交:通过技术手段自动推送新文章(适合开发者)。三、Bing 收录:一键复用 Google 配置Bing 是全球第二大搜索引擎,支持直接导入 Google 的收录配置,省时省力。1. 登录 Bing 站长平台访问 Bing 网站管理工具,点击 “添加站点”,输入博客地址。2. 一键导入 Google 数据在验证步骤选择 “导入 Google 搜索控制台数据”,授权后可直接复用 Google 的验证状态和 Sitemap 配置,无需重复操作。3. 等待收录提交后 Bing 会自动解析 Sitemap,收录进度可在 “站点地图” 页面查看。总结三大搜索引擎收录核心流程:平台验证 → 提交 Sitemap / 链接 → 等待抓取。Google:收录最快,优先推荐,适合全球用户;Baidu:聚焦国内,需手动提交新内容;Bing:支持导入 Google 配置,操作最简单。持续输出优质内容能加速收录,快去让你的博客被更多人看到吧!
2025年08月15日
23 阅读
0 评论
0 点赞
2025-08-15
解决 Mac 版 PicGo 无法打开问题:“已损坏,无法打开” 报错处理指南
作为一名经常需要处理图片上传的创作者或开发者,PicGo 这款图片管理工具无疑是提高效率的好帮手。它简洁的界面和便捷的图片上传功能,让我们能够轻松管理图片资源,无论是用于博客创作、文档编写还是日常工作,都能带来极大的便利。然而,在 Mac 电脑上安装好 PicGo 后,不少用户可能会遇到一个令人困扰的问题:双击运行 PicGo 时,系统会弹出报错窗口,提示 “PicGo.app” 已损坏,无法打开。你应该将它移到废纸篓,就像下图所示这样:这个问题并非是 PicGo 应用真的损坏了,而是 Mac 系统的安全机制在作祟。macOS 为了保护用户安全,会对从非 App Store 下载的应用进行严格的安全验证,当系统认为应用可能存在风险时,就会阻止其运行,从而出现上述报错。不过别担心,我们可以通过简单的操作来解决这个问题,让 PicGo 顺利运行。具体解决方案步骤一:打开终端在 Mac 电脑上,我们可以通过 Spotlight 搜索来快速打开终端。按下键盘上的Command + 空格组合键,调出 Spotlight 搜索框,然后输入 “终端” 并按下回车键,即可打开终端应用。步骤二:执行终端命令在打开的终端窗口中,输入以下命令:sudo xattr -d com.apple.quarantine "/Applications/PicGo.app"这里的sudo表示以管理员权限执行命令,xattr是用于操作文件扩展属性的命令,-d参数表示删除指定的扩展属性,com.apple.quarantine就是我们要删除的那个导致应用无法打开的扩展属性,而"/Applications/PicGo.app"则是 PicGo 应用在 Mac 上的安装路径。步骤三:输入密码并确认输入完上述命令后,按下回车键,终端会提示你输入密码。这里需要注意的是,在输入密码的过程中,终端不会显示任何字符,这是 Mac 系统的安全保护机制,你只需要正常输入你的电脑开机密码,然后按下回车键即可。输入密码并确认后,命令就会开始执行,执行完成后终端不会有特别的提示,就像下图这样:**步骤四:再次运行 PicGo完成以上操作后,回到 Applications(应用程序)文件夹,找到 PicGo 应用,双击它。这时候,你会发现 PicGo 能够正常打开了,再也不会出现之前的 “已损坏,无法打开” 报错了,就像下图所示:**注意事项确保 PicGo 应用的安装路径正确。上述命令中使用的是默认的安装路径/Applications/PicGo.app,如果你将 PicGo 安装在了其他路径下,需要将命令中的路径替换为实际的安装路径。输入密码时要仔细,确保输入正确。如果密码输入错误,终端会提示 “密码错误”,这时候你需要重新输入密码。执行命令时要保证网络连接正常,虽然这个操作本身不需要联网,但如果在操作过程中出现其他意外情况,联网状态可能有助于排查问题。总结通过以上几个简单的步骤,我们成功解决了 Mac 电脑上 PicGo 无法打开的问题。这个问题主要是由于 Mac 系统的安全机制导致的,并非应用本身真的损坏。只要我们按照上述方法,删除掉应用的 quarantine 扩展属性,就能让 PicGo 正常运行。希望这篇指南能够帮助到遇到同样问题的朋友,让大家能够顺利使用 PicGo 这款优秀的图片管理工具,提高工作和创作效率。
2025年08月15日
37 阅读
0 评论
1 点赞
2025-08-14
使用 CDN 给网站加速的保姆级教程:从卡顿到飞一般的体验
背景:为什么我需要 CDN?作为个人博客站长,我用的服务器配置不高,尤其是带宽有限。博客部署后总感觉加载慢吞吞的,打开 F12 开发者工具一看 ——静态资源(图片、CSS、JS)加载耗时占了 80% 以上。这时我想到了 CDN:它能把静态资源缓存到离用户最近的节点,既加速访问又减轻源站压力。这篇文章就以阿里云为例,手把手教你用 CDN 给网站提速。什么是 CDN?一句话看懂核心原理CDN(Content Delivery Network,内容分发网络)简单说就是 “分布式缓存网络”:它在全球部署了无数节点服务器,提前把你的静态资源(图片、视频、CSS 等)缓存到这些节点;用户访问时,会被智能路由到最近的节点,而不是直接请求你的源服务器;这样一来,距离缩短了、带宽压力分散了,加载速度自然快了。CDN 适合谁?个人博客 / 网站(静态资源多,带宽有限);电商网站(商品图片、视频多,用户分布广);直播 / 视频平台(大文件传输,需要低延迟)。实战:阿里云 CDN 配置全步骤以阿里云为例,从开通到生效只需 4 步,全程可视化操作,新手也能轻松搞定。 说明一下,我实际开通的是dcdn(全站加速),大体步骤是一致的,只有部分参数可能不一致,大家留意一下哈步骤 1:开通 CDN 服务,薅免费额度登录阿里云控制台,搜索 “内容分发网络 CDN” 进入服务页面;点击 “开通服务”,按提示完成实名认证(个人 / 企业均可);福利提醒:阿里云对新用户有免费 CDN 额度(通常是 50GB 流量 / 1年),在 “费用中心” 可查看。步骤 2:添加加速域名,配置源站这一步是核心,需要告诉 CDN “加速哪个域名” 和 “资源从哪里来”。进入 CDN 控制台,点击左侧 “域名管理”→“添加域名”;填写基础信息:加速区域:选 “中国大陆”(需域名已 ICP 备案,未备案可选 “全球(不含中国大陆)”);加速域名:填你要加速的域名(如static.lucaju.cn,建议用二级域名专门放静态资源);源站信息:填你的服务器 IP 或源站域名(即资源原本存放的地址)。验证域名所有权:按提示在域名解析平台(如阿里云 DNS、腾讯云 DNS)添加一条 TXT 记录,完成后点击 “验证”。参考我的配置:)步骤 3:配置 CNAME,让域名指向 CDN 节点添加域名后,CDN 会生成一个专属的 CNAME 域名(格式类似xxx.cdn.aliyuncs.com),需要把你的加速域名指向它,这样用户访问时才会走 CDN 节点。在 CDN 控制台的 “域名管理” 中,找到你的域名,复制对应的 “CNAME 地址”;进入域名解析平台,添加一条 “CNAME 记录”:记录值:粘贴复制的 CNAME 地址;保存后等待 10-30 分钟生效(DNS 解析需要时间)。验证是否生效:打开 CMD/PowerShell,输入ping 你的加速域名(如ping www.lucaju.cn),如果返回的是 CNAME 节点 记录,说明配置成功!步骤 4:可选配置:开启 HTTPS 加密如果你的网站用 HTTPS(推荐),需要给 CDN 配置 SSL 证书:在 CDN 控制台找到你的域名,点击 “配置”→“HTTPS 配置”;选择 “证书来源”:用阿里云免费证书:直接在 “SSL 证书” 服务申请,然后选择证书绑定;用已有证书:上传证书文件和私钥;开启 “强制 HTTPS”,确保所有请求都通过加密通道传输。步骤 5:配置缓存规则设置我们需要缓存的内容,已经对应的过期时间,我的配置如下效果对比:提速到底有多明显?配置前后用 F12 的 “网络” 面板测试,结果一目了然:未配置 CDN 前:静态资源全部从源站加载,图片、CSS 等大文件加载缓慢,单个图片耗时甚至超过 2 秒,总加载时间 8.3 秒。)配置 CDN 后:静态资源从 CDN 节点加载,大部分资源耗时降至 100-300 毫秒,总加载时间缩短到 1.5 秒,提速5 倍以上!)避坑指南:新手常踩的 3 个问题缓存不生效?检查 CNAME 是否配置正确(ping 域名看是否指向 CDN 节点),或在 CDN 控制台手动 “预热缓存”(让节点提前拉取资源)。流量消耗过快?在 CDN 控制台配置 “缓存规则”,只缓存静态资源(图片、JS、CSS),避免动态内容(如 PHP、JSP)被缓存浪费流量。额外提醒:警惕 CDN 流量暴增!避免被攻击导致欠费在享受 CDN 加速带来的便利时,一定要注意流量安全!如果网站被恶意攻击(如 DDoS、刷流量等),可能导致 CDN 流量暴增,甚至产生高额欠费。结合实战经验,分享几个避坑技巧:一、为什么会流量暴增?常见风险场景恶意刷量攻击:攻击者通过脚本反复请求你的静态资源(如图片、视频),消耗 CDN 流量;缓存配置不当:动态资源(如 API 接口)未排除缓存,被频繁请求后产生大量回源流量;资源被外链盗用:你的图片、视频被其他网站直接引用(“盗链”),白白消耗你的流量额度。二、增加防护措施,降低风险配置防盗链:只允许自家网站使用资源在 DCDN 控制台开启 “Referer 防盗链”,限制只有你的域名能访问资源:允许名单:添加你的主域名(如lucaju.cn、*.lucaju.cn);禁止空白 Referer:防止直接通过 URL 访问资源(如浏览器直接输入图片链接)。操作路径:阿里云 DCDN → 域名配置 → 基础配置 → 防盗链设置。CDN流量控制在CDN控制台管理 -> 流量限制中 可以配置流量封顶策略,及时下线域名服务总结CDN 是提升网站速度的 “性价比之王”,尤其适合静态资源多、带宽有限的个人网站。按本文步骤操作,从开通到生效不到 1 小时,就能让用户体验从 “卡顿” 变 “飞一般流畅”。但同时也要做好防护工作!
2025年08月14日
25 阅读
0 评论
0 点赞