- .NET Core 开发中的鉴权技术全解析
爱吃香蕉的阿豪
.netcore鉴权jwttoken
目录鉴权基础概念鉴权与授权的区别鉴权在.NETCore中的核心地位常见鉴权方式Cookie鉴权工作原理实现步骤JWT鉴权工作原理实现步骤OAuth2鉴权工作原理实现步骤(以Google登录为例)实际应用场景与选择策略不同场景下的鉴权技术应用鉴权技术选择策略总结鉴权基础概念鉴权与授权的区别特性鉴权(Authentication)授权(Authorization)目的验证用户身份(“你是谁?”)控制资
- 95.mysql5.7/MySQL8.0root密码忘记重置
戒掉贪嗔痴
数据库运维-MySQLmysql
1.mysql5.7密码重置方法mysql5.7--加参数vimy.cnf[mysqld]skip-grant-tables--重启systemctlrestartmysqld--修改密码USEmysql;FLUSHPRIVILEGES;UPDATEuserSETauthentication_string=PASSWORD('S3#1234')WHEREUser='root';EXIT;--注释v
- Github/Copilot 学生认证详细步骤
nomoremorphine
githubcopilot
Github学生认证详细步骤文章目录Github学生认证详细步骤1、注册github2、完善profile3、双重认证two-factorauthentication(必须)4、完善支付信息billingandplans5、学生认证5.1学信网获取学籍验证信息5.2通过翻译软件将学籍信息照片翻译为英文5.3使用手机拍照学籍信息照片(无法上传相册)6、确认完成认证1、注册github非学校邮箱注册的
- 【黑客与安全】开启Kali Linux的SSH接口
雾岛心情
黑客与安全服务器linux运维SSHkali
在没有开启KaliLinux的SSH功能之前,我们是无法使用工具利用ssh登录,这里面我们需要修改当前的机器的网络连接方式,如果是NAT方式的话我们需要修改为桥接模式。接下来我们需要配置ssh参数用来进行服务的启动,这里需要修改如下内容:修改sshd_config文件,命令为:vi/etc/ssh/sshd_config将#PasswordAuthenticationno的注释去掉,并且将NO修改
- Linux密码校验机制深度剖析:从shadow文件到crypt加密
算法练习生
高编linux服务器高编学习
Linux密码校验机制深度剖析:从shadow文件到crypt加密一、Linux密码安全体系概述Linux系统采用单向加密机制保护用户密码,即使获取加密后的密码串也无法逆向获取原始密码。核心组件包括:/etc/shadow文件-存储加密后的密码和账户策略PAM(PluggableAuthenticationModules)-可插拔认证模块加密算法-支持DES、MD5、SHA-256、SHA-512
- mysql忘记密码,workbench还以登录,mysql重置密码
asdfwxy
mysql数据库
SELECTUser,Host,authentication_stringFROMmysql.userWHEREUser=‘root’;ALTERUSER‘root’@‘localhost’IDENTIFIEDBY‘root’;FLUSHPRIVILEGES;
- Shiro技术原理与实战全景详解
北漂老男人
Shiro运维学习方法开发语言
Shiro技术原理与实战全景详解一、Shiro简介ApacheShiro是一款强大、易用的Java安全框架,提供了身份认证、授权、加密、会话管理等安全能力。它以简单易用、可插拔、灵活扩展著称,广泛应用于JavaEE、SpringBoot等主流技术栈。二、Shiro主流程环节与设计思想2.1主流程环节概览Shiro的核心流程分为四大环节:认证(Authentication):用户身份校验(登录)授权
- Django REST Framework(十七)Authentication
yjjpp2301
DjangoRESTframeworkdjangopython
1.认证Authentication在DjangoRESTframework(DRF)中,可以在配置文件中配置全局默认的认证方案。常见的认证方式包括cookie、session、和token。DRF提供了灵活的认证机制,可以在全局配置文件中设置默认认证方式,也可以在具体的视图类中设置单独的认证方式。以下是默认的配置文件示例,位于REST_FRAMEWORK={#配置认证方式的选项'DEFAULT_
- rest_framework permission_classes 无效的解决方法
bluemliu
python开发语言django
写了一个特别简单的view:@csrf_exempt@login_required()@authentication_classes([TokenAuthentication])@permission_classes([IsAdminUser,IsAuthenticated])defdepartment_management_view(request):ifrequest.method=='POS
- 【权限架构】2025年权限业务与技术清单
全栈前端老曹
前端业务实践技术清单系列架构前端javascript学习权限RBAC产品经理
2025年前端与权限相关的业务大讲解:20+技术点、难点、问题与解决方案一、技术视角的权限系统业务方向✅1.用户认证(Authentication)用户登录、登出Token管理(JWT/OAuth/Session)多因素认证(MFA)✅2.角色管理(RoleManagement)角色创建、编辑、删除角色继承(如admin>manager>user)角色绑定用户✅3.权限分配(PermissionA
- Flask-login 处理授权逻辑
fydw_715
Difyflaskpython后端
认证vs授权:在Web应用程序的安全机制中,认证(Authentication)和授权(Authorization)是两个核心概念,它们虽然紧密相关,但职责和作用不同。认证(Authentication):定义:认证是验证用户身份的过程,确定用户是谁。目的:确保请求访问系统资源的用户是合法的、已知的,并且其身份已被验证。实现方式:通常通过用户提供凭证(如用户名和密码、令牌、指纹等)来完成身份验证。
- MongoDB中使用的SCRAM-SHA1认证机制
weixin_34250434
数据库javaphp
介绍SCRAM是密码学中的一种认证机制,全称SaltedChallengeResponseAuthenticationMechanism。SCRAM适用于使用基于『用户名:密码』这种简单认证模型的连接协议。SCRAM是一个抽象的机制,在其设计中需要用到一个哈希函数,这个哈希函数是客户端和服务端协商好的,包含在具体的机制名称中。比如SCRAM-SHA1,使用SHA1作为其哈希函数。前言基于『用户名:
- springboot连接Redis报NOAUTH Authentication required
无极之岚
springbootredis后端
背景项目接入redis,连接报错NOAUTHAuthenticationrequired,百度后是没有输入密码,但是在测试环境是正常的。修改多次密码失效,直接使用redis-cli连接,也是只有没输入密码时才会报这个错,密码错误是另一个提示。那应该和redis版本和redis客户端有关根因redis3.0版本仅支持RESP2的通信协议,而Lettuce6.x版本开始,使用RESP3(Redis6.
- Spring Security重写AuthenticationManager实现账号或者手机号码登录
奔向理想的星辰大海
Java研发实用技巧springjava前端
SpringSecurity默认使用账号密码进行登录,通过将账号密码写入到UsernamePasswordAuthenticationToken中,认证成功后创建一个包含用户信息和权限的认证令牌;在UsernamePasswordAuthenticationToken认证的时候,调用UserDetailsService进行校验(此次可以自己写逻辑进行校验,如查数据库),并且返回UserDetail
- 《网络安全与防护》知识点复习
忘川w
网络安全与防护web安全安全笔记网络安全
✅一、网络安全基础(CIA/AAA/安全服务)概念快速记忆CIA三元组机密性(Confidentiality)、完整性(Integrity)、可用性(Availability)安全服务(OSI)鉴别服务+访问控制+数据完整性+数据保密性+抗抵赖AAA模型认证(Authentication)→授权(Authorization)→记账(Accounting)OSI安全体系结构口诀法:“机密-完整-可用
- FastAPI系列教程12:使用JWT 登录认证和RBAC 权限控制
GeekABC
PythonFastAPI实战教程fastapiweb安全
使用JWT登录认证和RBAC权限控制1、身份认证(Authentication)与JWT身份认证(Authentication)的方式JWT(JSONWebToken)的实现原理2、授权(Authorization)与RBAC授权(Authorization)的方式RBAC的实现原理3、FastAPI实现JWT与RBAC实现思路完整的实现代码在开发WebAPI应用时,安全问题是非常核心的考虑因素。
- MySQL用户管理与权限控制详解
拓海家的豆腐店
MySQLmysqlandroid数据库
一、用户表(user)核心结构MySQL用户账户信息存储在系统数据库mysql的user表中,核心字段解析:字段名称说明示例值user用户名(唯一标识)adminhost允许登录的主机地址(支持通配符)localhost/%.example.com/192.168.1.%authentication_string加密后的登录密码(MySQL5.7+使用caching_sha2_password默认
- Spring Security
一、基础概念与核心原理1.SpringSecurity是什么?定位:Spring生态中的安全框架,用于实现Web应用的身份验证(Authentication)和授权(Authorization)。核心功能:防止未经授权的访问(如登录认证)。细粒度的权限控制(如角色/权限管理)。支持多种认证方式(如用户名密码、OAuth2、JWT等)。防御常见安全攻击(如CSRF、XSS、Session固定等)。2
- SpringSecurity身份验证之AuthenticationProvider接口
别团等shy哥发育
SpringSecurityspringbootspringspringsecurity
理解AuthenticationProvider1、简介1.1在身份验证期间表示请求1.2实现自定义身份验证逻辑1.3应用自定义身份验证逻辑1.3.1实现步骤1.3.2重写AuthenticationProvider的supports()方法1.3.3实现身份验证逻辑1.3.4在配置类中注册AuthenticationProvider1、简介 在企业级应用程序中,你可能会发现自己处于这样一种状况
- Spring Security是如何完成身份认证的?
fajianchen
技术战术服务器运维
1.用户名和密码被过滤器获取到,封装成Authentication,通常情况下是UsernamePasswordAuthenticationToken这个实现类。2.AuthenticationManager身份管理器负责验证这个Authentication3.认证成功后,AuthenticationManager身份管理器返回一个被填充满了信息的(包括上面提到的权限信息,身份信息,细节信息,但密
- SpringSecurity登陆后,如何获取用户的登录信息
雾林小妖
java项目解决方案javasecurity获取登录信息
1、问题概述?SpringSecurity默认通过loadUserByUsername登录成功后,我们期望在项目中使用登录后的用户信息。2、在Controller中获取用户的登录信息。主要通过Authentication对象进行查询@RequestMapping("/checkRemoteDevice")@ResponseBodypublicvoidcheckRemoteDevice(Authen
- 详解Spring Security中获取当前登录用户的详细信息的几种方法
今天的接口写完了吗?
SpringSecurityspringjava后端
下面就来详细讲解一下SpringSecurity获取当前登录用户的详细信息的几种方法。1.使用Authentication对象获取当前登录用户信息在SpringSecurity中,用户需要进行身份验证后才能访问受保护的资源。在用户访问受保护的资源时,SpringSecurity会将用户的认证信息存储在一个名为Authentication的对象中。因此,我们可以通过获取当前Authenticatio
- Spring Security - 获取当前登录用户的详细信息
HD243608836
springspringBootspringSecurity获取登录用户信息
原文格式清晰,转载自:https://blog.csdn.net/cloume/article/details/84983006#commentBoxSpringSecurity-获取当前登录用户的详细信息在Spring框架里面,可以通过以下几种方式获取到当前登录用户的详细信息:1.在Bean中获取用户信息Authenticationauthentication=SecurityContextHo
- Spring Security如何拿到登录用户的信息
結城
Javaspringmybatisjava
书接上文,我们刚实现了一个简单的登录功能,那么我们要如何才能拿到登录用户的具体信息呢?我进行了一下整理“登录用户的信息”是保存在SecurityContext里的,可以通过多种方式获取这个用户的信息,下面是最常用的方式:在Controller里用@AuthenticationPrincipal@GetMapping("/me")publicStringgetCurrentUser(@Authent
- ASP.NET Core身份验证的深度解析
t0_54coder
编程问题解决手册asp.net后端个人开发
引言在ASP.NETCore应用程序中,身份验证(Authentication)和授权(Authorization)是两个非常重要的安全机制。它们确保只有经过认证的用户可以访问特定的资源或执行特定的操作。今天,我们将探讨一个常见的身份验证问题,并通过实例说明如何正确处理身份验证失败的情况。身份验证流程在ASP.NETCore中,身份验证通常通过中间件(Middleware)来处理。Authenti
- 云原生安全实战:API网关Kong的鉴权与限流详解
「炎码工坊」技术弹药已装填!点击关注→解锁工业级干货【工具实测|项目避坑|源码燃烧指南】一、基础概念1.API网关(APIGateway)API网关是微服务架构中的核心组件,负责统一管理所有API的流量入口。它像一座桥梁,连接客户端与后端服务,提供身份验证、流量控制、监控日志等能力。核心作用:集中管理API安全策略统一处理跨服务通信提供可扩展的插件化架构2.鉴权(Authentication&Au
- API Server如何集成自定义准入策略?
alden_ygq
#Kubernetes系列k8s
在Kubernetes中,APIServer的自定义准入策略(AdmissionControl)允许你在资源创建、更新或删除时执行自定义验证和修改逻辑。以下是集成自定义准入策略的详细流程:一、核心组件与流程1.客户端请求用户通过kubectl、SDK或直接调用API发送资源操作请求(CREATE/UPDATE/DELETE)。2.APIServer处理阶段认证(Authentication)验证请
- SpringBoot集成Spring Security全解:从入门到精通实战指南(亲测可用)
Clf丶忆笙
#安全与认证springspringboot后端javaSecurity
文章目录一、SpringSecurity基础概念与核心原理1.1认证(Authentication)与授权(Authorization)的区别1.2SpringSecurity核心架构1.3SpringSecurity过滤器链二、SpringBoot集成SpringSecurity基础配置2.1创建项目并添加依赖2.2基础安全配置类2.3控制器代码示例2.4自定义登录页面三、认证机制深度解析3.1
- Linux----Ubuntu基本命令(目录结构、sudo--Authentication failure解决方案、基本指令)
蹦蹦跳跳真可爱589
linuxlinux运维服务器
一、Linux目录在Linux中,所有东西都被当做是文件,包括硬件、进程、命令、系统设置、目录等,整个目录以根目录左斜杠/为起点。目录下的层级也使用/来分割(与Windows相反)。所有其他目录和文件都位于根目录的子目录中。1.1、目录的解释系统启动必须:/boot:存放的启动Linux时使用的内核文件,包括连接文件以及镜像文件。/etc:存放所有的系统需要的配置文件和子目录列表,更改目录下的文件
- docker安装kafka并使用SASL 进行身份验证
半桶水专家
kafkadockerdockerkafka容器
在Docker中安装Kafka并配置SASL(SimpleAuthenticationandSecurityLayer)进行身份验证,能够确保Kafka集群的安全性。SASL是一种常见的认证机制,Kafka支持多种SASL协议,常见的有:SASL/PLAIN:使用用户名和密码进行简单认证。SASL/SCRAM:比PLAIN更安全,使用加密的存储机制。SASL/GSSAPI(Kerberos):使用
- jsonp 常用util方法
hw1287789687
jsonpjsonp常用方法jsonp callback
jsonp 常用java方法
(1)以jsonp的形式返回:函数名(json字符串)
/***
* 用于jsonp调用
* @param map : 用于构造json数据
* @param callback : 回调的javascript方法名
* @param filters : <code>SimpleBeanPropertyFilter theFilt
- 多线程场景
alafqq
多线程
0
能不能简单描述一下你在java web开发中需要用到多线程编程的场景?0
对多线程有些了解,但是不太清楚具体的应用场景,能简单说一下你遇到的多线程编程的场景吗?
Java多线程
2012年11月23日 15:41 Young9007 Young9007
4
0 0 4
Comment添加评论关注(2)
3个答案 按时间排序 按投票排序
0
0
最典型的如:
1、
- Maven学习——修改Maven的本地仓库路径
Kai_Ge
maven
安装Maven后我们会在用户目录下发现.m2 文件夹。默认情况下,该文件夹下放置了Maven本地仓库.m2/repository。所有的Maven构件(artifact)都被存储到该仓库中,以方便重用。但是windows用户的操作系统都安装在C盘,把Maven仓库放到C盘是很危险的,为此我们需要修改Maven的本地仓库路径。
- placeholder的浏览器兼容
120153216
placeholder
【前言】
自从html5引入placeholder后,问题就来了,
不支持html5的浏览器也先有这样的效果,
各种兼容,之前考虑,今天测试人员逮住不放,
想了个解决办法,看样子还行,记录一下。
【原理】
不使用placeholder,而是模拟placeholder的效果,
大概就是用focus和focusout效果。
【代码】
<scrip
- debian_用iso文件创建本地apt源
2002wmj
Debian
1.将N个debian-506-amd64-DVD-N.iso存放于本地或其他媒介内,本例是放在本机/iso/目录下
2.创建N个挂载点目录
如下:
debian:~#mkdir –r /media/dvd1
debian:~#mkdir –r /media/dvd2
debian:~#mkdir –r /media/dvd3
….
debian:~#mkdir –r /media
- SQLSERVER耗时最长的SQL
357029540
SQL Server
对于DBA来说,经常要知道存储过程的某些信息:
1. 执行了多少次
2. 执行的执行计划如何
3. 执行的平均读写如何
4. 执行平均需要多少时间
列名 &
- com/genuitec/eclipse/j2eedt/core/J2EEProjectUtil
7454103
eclipse
今天eclipse突然报了com/genuitec/eclipse/j2eedt/core/J2EEProjectUtil 错误,并且工程文件打不开了,在网上找了一下资料,然后按照方法操作了一遍,好了,解决方法如下:
错误提示信息:
An error has occurred.See error log for more details.
Reason:
com/genuitec/
- 用正则删除文本中的html标签
adminjun
javahtml正则表达式去掉html标签
使用文本编辑器录入文章存入数据中的文本是HTML标签格式,由于业务需要对HTML标签进行去除只保留纯净的文本内容,于是乎Java实现自动过滤。
如下:
public static String Html2Text(String inputString) {
String htmlStr = inputString; // 含html标签的字符串
String textSt
- 嵌入式系统设计中常用总线和接口
aijuans
linux 基础
嵌入式系统设计中常用总线和接口
任何一个微处理器都要与一定数量的部件和外围设备连接,但如果将各部件和每一种外围设备都分别用一组线路与CPU直接连接,那么连线
- Java函数调用方式——按值传递
ayaoxinchao
java按值传递对象基础数据类型
Java使用按值传递的函数调用方式,这往往使我感到迷惑。因为在基础数据类型和对象的传递上,我就会纠结于到底是按值传递,还是按引用传递。其实经过学习,Java在任何地方,都一直发挥着按值传递的本色。
首先,让我们看一看基础数据类型是如何按值传递的。
public static void main(String[] args) {
int a = 2;
- ios音量线性下降
bewithme
ios音量
直接上代码吧
//second 几秒内下降为0
- (void)reduceVolume:(int)second {
KGVoicePlayer *player = [KGVoicePlayer defaultPlayer];
if (!_flag) {
_tempVolume = player.volume;
- 与其怨它不如爱它
bijian1013
选择理想职业规划
抱怨工作是年轻人的常态,但爱工作才是积极的心态,与其怨它不如爱它。
一般来说,在公司干了一两年后,不少年轻人容易产生怨言,除了具体的埋怨公司“扭门”,埋怨上司无能以外,也有许多人是因为根本不爱自已的那份工作,工作完全成了谋生的手段,跟自已的性格、专业、爱好都相差甚远。
- 一边时间不够用一边浪费时间
bingyingao
工作时间浪费
一方面感觉时间严重不够用,另一方面又在不停的浪费时间。
每一个周末,晚上熬夜看电影到凌晨一点,早上起不来一直睡到10点钟,10点钟起床,吃饭后玩手机到下午一点。
精神还是很差,下午像一直野鬼在城市里晃荡。
为何不尝试晚上10点钟就睡,早上7点就起,时间完全是一样的,把看电影的时间换到早上,精神好,气色好,一天好状态。
控制让自己周末早睡早起,你就成功了一半。
有多少个工作
- 【Scala八】Scala核心二:隐式转换
bit1129
scala
Implicits work like this: if you call a method on a Scala object, and the Scala compiler does not see a definition for that method in the class definition for that object, the compiler will try to con
- sudoku slover in Haskell (2)
bookjovi
haskellsudoku
继续精简haskell版的sudoku程序,稍微改了一下,这次用了8行,同时性能也提高了很多,对每个空格的所有解不是通过尝试算出来的,而是直接得出。
board = [0,3,4,1,7,0,5,0,0,
0,6,0,0,0,8,3,0,1,
7,0,0,3,0,0,0,0,6,
5,0,0,6,4,0,8,0,7,
- Java-Collections Framework学习与总结-HashSet和LinkedHashSet
BrokenDreams
linkedhashset
本篇总结一下两个常用的集合类HashSet和LinkedHashSet。
它们都实现了相同接口java.util.Set。Set表示一种元素无序且不可重复的集合;之前总结过的java.util.List表示一种元素可重复且有序
- 读《研磨设计模式》-代码笔记-备忘录模式-Memento
bylijinnan
java设计模式
声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/
import java.util.ArrayList;
import java.util.List;
/*
* 备忘录模式的功能是,在不破坏封装性的前提下,捕获一个对象的内部状态,并在对象之外保存这个状态,为以后的状态恢复作“备忘”
- 《RAW格式照片处理专业技法》笔记
cherishLC
PS
注意,这不是教程!仅记录楼主之前不太了解的
一、色彩(空间)管理
作者建议采用ProRGB(色域最广),但camera raw中设为ProRGB,而PS中则在ProRGB的基础上,将gamma值设为了1.8(更符合人眼)
注意:bridge、camera raw怎么设置显示、输出的颜色都是正确的(会读取文件内的颜色配置文件),但用PS输出jpg文件时,必须先用Edit->conv
- 使用 Git 下载 Spring 源码 编译 for Eclipse
crabdave
eclipse
使用 Git 下载 Spring 源码 编译 for Eclipse
1、安装gradle,下载 http://www.gradle.org/downloads
配置环境变量GRADLE_HOME,配置PATH %GRADLE_HOME%/bin,cmd,gradle -v
2、spring4 用jdk8 下载 https://jdk8.java.
- mysql连接拒绝问题
daizj
mysql登录权限
mysql中在其它机器连接mysql服务器时报错问题汇总
一、[running]
[email protected]:~$mysql -uroot -h 192.168.9.108 -p //带-p参数,在下一步进行密码输入
Enter password: //无字符串输入
ERROR 1045 (28000): Access
- Google Chrome 为何打压 H.264
dsjt
applehtml5chromeGoogle
Google 今天在 Chromium 官方博客宣布由于 H.264 编解码器并非开放标准,Chrome 将在几个月后正式停止对 H.264 视频解码的支持,全面采用开放的 WebM 和 Theora 格式。
Google 在博客上表示,自从 WebM 视频编解码器推出以后,在性能、厂商支持以及独立性方面已经取得了很大的进步,为了与 Chromium 现有支持的編解码器保持一致,Chrome
- yii 获取控制器名 和方法名
dcj3sjt126com
yiiframework
1. 获取控制器名
在控制器中获取控制器名: $name = $this->getId();
在视图中获取控制器名: $name = Yii::app()->controller->id;
2. 获取动作名
在控制器beforeAction()回调函数中获取动作名: $name =
- Android知识总结(二)
come_for_dream
android
明天要考试了,速速总结如下
1、Activity的启动模式
standard:每次调用Activity的时候都创建一个(可以有多个相同的实例,也允许多个相同Activity叠加。)
singleTop:可以有多个实例,但是不允许多个相同Activity叠加。即,如果Ac
- 高洛峰收徒第二期:寻找未来的“技术大牛” ——折腾一年,奖励20万元
gcq511120594
工作项目管理
高洛峰,兄弟连IT教育合伙人、猿代码创始人、PHP培训第一人、《细说PHP》作者、软件开发工程师、《IT峰播》主创人、PHP讲师的鼻祖!
首期现在的进程刚刚过半,徒弟们真的很棒,人品都没的说,团结互助,学习刻苦,工作认真积极,灵活上进。我几乎会把他们全部留下来,现在已有一多半安排了实际的工作,并取得了很好的成绩。等他们出徒之日,凭他们的能力一定能够拿到高薪,而且我还承诺过一个徒弟,当他拿到大学毕
- linux expect
heipark
expect
1. 创建、编辑文件go.sh
#!/usr/bin/expect
spawn sudo su admin
expect "*password*" { send "13456\r\n" }
interact
2. 设置权限
chmod u+x go.sh 3.
- Spring4.1新特性——静态资源处理增强
jinnianshilongnian
spring 4.1
目录
Spring4.1新特性——综述
Spring4.1新特性——Spring核心部分及其他
Spring4.1新特性——Spring缓存框架增强
Spring4.1新特性——异步调用和事件机制的异常处理
Spring4.1新特性——数据库集成测试脚本初始化
Spring4.1新特性——Spring MVC增强
Spring4.1新特性——页面自动化测试框架Spring MVC T
- idea ubuntuxia 乱码
liyonghui160com
1.首先需要在windows字体目录下或者其它地方找到simsun.ttf 这个 字体文件。
2.在ubuntu 下可以执行下面操作安装该字体:
sudo mkdir /usr/share/fonts/truetype/simsun
sudo cp simsun.ttf /usr/share/fonts/truetype/simsun
fc-cache -f -v
- 改良程序的11技巧
pda158
技巧
有很多理由都能说明为什么我们应该写出清晰、可读性好的程序。最重要的一点,程序你只写一次,但以后会无数次的阅读。当你第二天回头来看你的代码 时,你就要开始阅读它了。当你把代码拿给其他人看时,他必须阅读你的代码。因此,在编写时多花一点时间,你会在阅读它时节省大量的时间。
让我们看一些基本的编程技巧:
尽量保持方法简短
永远永远不要把同一个变量用于多个不同的
- 300个涵盖IT各方面的免费资源(下)——工作与学习篇
shoothao
创业免费资源学习课程远程工作
工作与生产效率:
A. 背景声音
Noisli:背景噪音与颜色生成器。
Noizio:环境声均衡器。
Defonic:世界上任何的声响都可混合成美丽的旋律。
Designers.mx:设计者为设计者所准备的播放列表。
Coffitivity:这里的声音就像咖啡馆里放的一样。
B. 避免注意力分散
Self Co
- 深入浅出RPC
uule
rpc
深入浅出RPC-浅出篇
深入浅出RPC-深入篇
RPC
Remote Procedure Call Protocol
远程过程调用协议
它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据。在OSI网络通信模型中,RPC跨越了传输层和应用层。RPC使得开发