- 每天一个前端小知识 Day 17 - 微前端架构实战与 Module Federation
微前端架构实战与ModuleFederation为什么要微前端?✅传统SPA的问题:问题描述构建时间越来越长单体应用构建缓慢,难以增量部署多团队协作困难不同业务线互相依赖紧耦合技术栈难以迁移老项目技术债,无法局部替换✅微前端目标:像微服务一样拆前端系统各子应用独立开发、独立部署、独立运行支持多技术栈共存(React+Vue+原生)核心架构方案一览架构方式技术实现适用场景iframe方式每个子应用独
- 每天一个前端小知识 Day 28 - Web Workers / 多线程模型在前端中的应用实践
蓝婷儿
前端面试前端
WebWorkers/多线程模型在前端中的应用实践一、为什么前端需要多线程?单线程JS的瓶颈:浏览器主线程不仅负责执行JS,还要负责:UI渲染(DOM/CSS)用户事件处理(点击、输入)一旦JS执行耗时任务(如大数组处理、加密运算),会阻塞页面响应多线程的意义:✅把计算密集型或IO密集型任务移出主线程,防止“卡死”✅实现离线计算、并发执行、后台数据同步✅提升用户体验、增强系统鲁棒性二、前端中的“线
- 每天一个前端小知识 Day 23 - PWA 渐进式 Web 应用开发
蓝婷儿
python前端
PWA渐进式Web应用开发(离线缓存、桌面安装等)一、什么是PWA?PWA(ProgressiveWebApp)是一种让Web应用具有类似原生App用户体验的技术体系。PWA不是一个框架,而是由一组浏览器API组成的技术集合,包括:离线访问能力WebApp安装到桌面推送通知后台同步原生风格UIPWA的三大核心能力能力描述可安装性支持添加到桌面启动器,像原生App打开离线能力使用ServiceWor
- 每天一个前端小知识 Day 19 - 前端 CI/CD 自动化部署体系全流程
蓝婷儿
前端面试前端ci/cd自动化
前端CI/CD自动化部署体系全流程CI/CD是什么?概念解释CI(持续集成)自动构建+自动测试+合并提交CD(持续部署)自动部署到测试/生产服务器目标是:让代码一提交,自动构建→测试→上线→通知,提高发布效率和质量。一、完整的前端部署流程概览1.提交代码到Git仓库(如GitHub)↓2.触发CI流程(如GitHubActions)↓3.安装依赖、构建产物(npmrunbuild)↓4.自动化测试
- 每天一个前端小知识 Day 20 - 服务端渲染(SSR)与前后端一体化开发详解
蓝婷儿
前端面试前端
服务端渲染(SSR)与前后端一体化开发详解什么是服务端渲染(SSR)?SSR(Server-SideRendering)是指在服务端生成HTML页面并返回给浏览器,由浏览器完成后续的交互逻辑绑定。✅SSR与CSR(客户端渲染)的对比特点SSRCSR首屏速度更快(服务端返回完整HTML)慢(JS加载后再渲染)SEO友好,搜索引擎可抓取完整内容差(默认JS执行后才有内容)页面加载方式首次由服务端渲染,
- 每天一个前端小知识 Day 16 - 前端性能优化全流程指南
蓝婷儿
前端面试前端性能优化
前端性能优化全流程指南(从加载到交互)目标概览:前端性能优化四大核心维度阶段优化目标加载阶段首屏速度、资源压缩、请求优化渲染阶段减少回流重绘、避免布局抖动交互阶段保持高帧率、避免卡顿持久运行阶段内存泄露处理、缓存命中策略一、加载性能优化(首屏速度为王)✅核心策略:资源体积优化JS/CSS/图片压缩(如gzip,brotli)Tree-shaking(去除无用代码)图片压缩(webp优先)合理拆包(
- 每天一个前端小知识 Day 14 - 前端状态管理深入实践
蓝婷儿
前端面试前端
前端状态管理深入实践(Redux、Pinia、Zustand等)为什么需要状态管理?当组件之间状态通信越来越复杂时,靠props和事件传递会变得非常难维护。状态管理工具提供:目标实现方式状态集中管理将状态集中存放,避免组件深层传递状态可预测、可追踪有清晰的流转逻辑(Action→Reducer→Store)跨组件通信无需propsdrilling(逐层传递)支持模块拆分与中间件支持插件化、按模块加
- 每天一个前端小知识 Day 10 - 代码质量保障与团队协作实践
蓝婷儿
前端面试前端
代码质量保障与团队协作实践1.为什么代码规范与协作流程如此重要?减少沟通与协作成本;降低维护成本,提升团队效率;提高可读性,方便代码review;防止低级bug与语义不清的问题;为CI/CD奠定基础。代码好不好,看的不是能不能跑,而是能否在千人项目中跑十年不崩溃2.Lint工具链:ESLint+Prettier✅ESLint:代码质量检查npxeslintsrc/**/*.ts基于规则自动检测潜在
- 每天一个前端小知识 Day 8 - 网络通信与前端性能优化
网络通信与前端性能优化1.前端常用网络通信方式对比方式场景说明特点XMLHttpRequest老式AJAX通信回调繁琐,兼容性好fetchAPI现代标准,逐步取代XHRPromise基础,更简洁axios基于xhr的封装库拦截器、默认配置、适配性强WebSocket实时通信,如聊天室、推送长连接,双向通信SSE服务端单向推送(Server-Sent)比WebSocket简单,单向2.fetchAP
- 每天一个前端小知识 Day 7 - 现代前端工程化与构建工具体系
蓝婷儿
前端
现代前端工程化与构建工具体系1.为什么要工程化?(面试高频问题)问题痛点:模块太多、无法组织;代码冗长、性能差;浏览器兼容性差;团队协作混乱,缺少规范与自动化。工程化目标:✅提升开发效率✅保证代码质量✅实现构建优化与产出部署自动化2.模块化规范回顾(理解构建目标)模块规范适用环境示例IIFE早期浏览器(function(){})()CommonJSNode.jsconstfs=require('f
- 每天一个前端小知识 Day 3 - JavaScript 的作用域与闭包
蓝婷儿
前端面试前端javascript
JavaScript的作用域与闭包1.什么是作用域(Scope)?作用域是变量定义的可访问范围。分类:类型说明全局作用域在任何地方都能访问的变量(如浏览器中window)函数作用域函数内部定义的变量只能在函数内部访问块级作用域(ES6)使用let、const创建的变量,限制在{}中示例:vara=1;//全局作用域functionfoo(){varb=2;//函数作用域if(true){letc=
- 每天一个前端小知识 Day 4 - TypeScript 核心类型系统与实践
蓝婷儿
前端面试前端typescriptjavascript
TypeScript核心类型系统与实践1.为什么前端面试中越来越重视TypeScript?复杂业务场景需要强类型保障稳定性;更好的IDE支持和智能提示;降低线上bug概率;成熟的工程团队都在使用;对于React/Vue项目维护可读性更强。2.TypeScript的核心类型✅原始类型letstr:string='hello';letnum:number=123;letflag:boolean=tru
- 每天一个前端小知识 Day 2 - Flexbox 布局模型
蓝婷儿
前端面试前端css3
Flexbox布局模型(CSSFlex弹性盒模型)1.为什么要学习Flexbox?传统布局方式(如float,inline-block,table)存在:居中困难;等高列实现繁琐;代码不够语义化;响应式适配能力差。而Flexbox(CSSFlexibleBoxLayout)为这些常见问题提供了简洁、强大、现代化的解决方案,适合构建一维方向的布局(横排或竖排)。2.Flexbox核心概念容器与项目(
- 每天10个前端小知识 <Day 19>
前端小天才
前端
前端面试基础知识题1.什么是BFC?BFC:blockformattingcontext,块级格式化上下文。BFC是Web页面的可视CSS渲染的一部分,是块盒子的布局过程发生的区域,也是浮动元素与其他元素交互的区域。定位方案:内部的Box会在垂直方向上一个接一个放置。Box垂直方向的距离由margin决定,属于同一个BFC的两个相邻Box的margin会发生重叠。每个元素的marginbox的左边
- 每天10个前端小知识 <Day 10>
前端小天才
前端
前端面试基础知识题1.bind、call、apply有什么区别?如何实现一个bind?apply、call、bind三者的区别在于:三者都可以改变函数的this对象指向三者第一个参数都是this要指向的对象,如果如果没有这个参数或参数为undefined或null,则默认指向全局window三者都可以传参,但是apply是数组,而call是参数列表,且apply和call是一次性传入参数,而bin
- 每天10个前端小知识 <Day 1>
前端小天才
前端
前端面试基础知识题1.将数组的length设置为0,取第一个元素会返回什么?设置length=0会清空数组,所以会返回undefined2.e.target和e.currentTarget有什么区别?e.target:触发事件的元素e.currentTarget:绑定事件的元素3.如何获取到一个实例对象的原型对象?从构造函数获得原型对象:构造函数.prototype从对象实例获得父级原型对象:方法
- 每天10个前端小知识 <Day 7>
前端小天才
前端状态模式
前端面试基础知识题1.什么是尾调用优化和尾递归?尾调用的概念非常简单,一句话就能说清楚,就是指某个函数的最后一步是调用另一个函数。functionf(x){returng(x);}上面代码中,函数f的最后一步是调用函数g,这就叫尾调用。尾调用优化尾调用之所以与其他调用不同,就在于它的特殊的调用位置。我们知道,函数调用会在内存形成一个"调用记录",又称"调用帧"(callframe),保存调用位置和
- 今日前端小知识—— width:auto 与 width:100% 的区别
ostuthere
CSScsscss3html
前段时间做页面的时候,发现给盒子设置width:100%和auto的效果不一样,这里来探讨一下。.main{width:300px;height:auto;padding:20px;background-color:brown;color:seashell;}.box1{width:100%;background-color:chocolate;}.box2{width:auto;backgrou
- 前端小知识点总结
养羊得亿
正则表达式gitjavascript
typeof与instanceoftypeof返回string、Boolean、number、function、object、undefined6种注意null类型返回objectinstanceof意为实例,及返回对象的构造函数。懒加载和预加载区别懒加载:使用到的时候在加载预加载:提前加载所以懒加载是减少前端压力,预加载增加前端压力,但优化用户体验。懒加载:一开始为空,不请求资源,但是占位当图片
- 今日前端小知识——遍历对象的方法
ostuthere
JavaScript前端javascriptjs
遍历对象的5种方法for...in...Object.entries()/Object.keys()/Object.values()Object.getOwnPropertyNames(targetObj)Object.getOwnPropertySymbols(targetObj)Reflect.ownKeys(targetObj)总结补充知识点可迭代对象可枚举属性Object.definePr
- 今日前端小知识——数组去重的方法
ostuthere
JavaScript前端javascript
数组去重双重for循环遍历+splice()for循环遍历+indexOf()+splice()filter()+indexOf()借用新数组+for循环遍历+indexOf()借用新数组+for循环遍历+includes()借用新数组+for循环遍历+some()利用ES6新增的数据结构——集合Set现在有一个数组,存在一些重复元素,如下letarr=[1,1,'a','b',true,unde
- 前端小知识--区分get和post请求
JiAyInNnNn
get和post是HTTP协议中的两种发送请求的方法。如果你还不了解http,可以点击HTTP协议①介绍HTTP协议②缓存首先先说get使用query接收get数据eg:http://127.0.0.1:3000/index?id=10001&name=zsreq.query中以对象的形式保存了get参数{id=1001,name="zs"}使用params接收get数据eg:http://127
- 前端小知识储备(二):BFC
weixin_34390996
前端ViewUI
BFCBFC:“块级格式化上下文”,是一种盒模型的渲染规则。BFC渲染规则在BFC元素中,垂直方向上的margin会发生重叠(取最大值)。BFC元素是独立的容器,外面的元素和里面的元素互不影响。BFC元素不会和浮动元素重叠(可用于两栏自适应布局)。计算BFC元素的高度时,里面浮动元素的高度也会参加计算。内部的盒子会在垂直方向依次放置。那么,怎么创建BFC呢?根元素html就是一个BFC容器。flo
- 前端小知识点总结
DistanceMJ
关于表单:placeholderinput默认样式修改:input::-webkit-input-placeholder{/*WebKitbrowsers*/font-size:14px;}input::-moz-placeholder{/*MozillaFirefox4to18*/font-size:14px;}input::-moz-placeholder{/*MozillaFirefox19
- 前端小知识之【浏览器内核】
忆凡_
前端前端
目录前言PC端浏览器内核Trident内核Gecko内核WebKit内核(Chromium)Blink内核移动端浏览器内核应用写在最后前言通常所谓的浏览器内核也就是浏览器所采用的渲染引擎,渲染引擎决定了浏览器如何显示网页的内容以及页面的格式信息。不同的浏览器内核对网页编写语法的解释也有不同,因此同一网页在不同的内核的浏览器里的渲染(显示)效果也可能不同,这也是网页编写者需要在不同内核的浏览器中测试
- 前端小知识
蛙夏~
javaScriptvue前端javascript
文章目录1、禁止在浏览器上复制文字2、滚动条滚动到页面顶部3、js获取地址栏上某个参数值4、使用正则表达式匹配字符串中,a标签的href值5、禁止原生input标签,按下回车键自动打开下载弹窗6、从字符串中,找出a标签的href值1、禁止在浏览器上复制文字//禁用浏览器右键功能document.oncontextmenu=newFunction("event.returnValue=false")
- 30+ 个工作中常用到的前端小知识
抽疯的稻草绳
1.JS为什么单线程一个简单的原因就是,js在设计之初只是进行一些简单的表单校验,这完全不需要多线程,单线程完全可以胜任这项工作。即便后来前端发展迅速,承载的能力越来越多,也没有发展到非多线程不可的程度。而且还有一个主要的原因,设想一下,如果js是多线程的,在运行时多个线程同时对DOM元素进行操作,那具体以哪个线程为主就是个问题了,线程的调度问题是一个比较复杂的问题。HTML5新的标准中允许使用n
- 每天10个前端小知识 【Day 11】
不爱吃糖的程序媛
面试宝典#ES6前端前端面试前端面试题
个人主页:不爱吃糖的程序媛♂️作者简介:前端领域新星创作者、CSDN内容合伙人,专注于前端各领域技术,成长的路上共同学习共同进步,一起加油呀!✨系列专栏:前端面试宝典、JavaScript进阶、vue实战资料领取:前端进阶资料以及文中源码可以在公众号【不爱吃糖的程序媛】领取前端面试基础知识题1.浏览器的垃圾回收机制有哪些?JS会在创建变量时自动分配内存,在不使用的时候会自动周期性的释放内存,释放
- 15个前端小知识
魂斗罗小黑
css一行文本超出...overflow:hidden;text-overflow:ellipsis;white-space:nowrap;2.多行文本超出显示...display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;overflow:hidden;3.IOS手机容器滚动条滑动不流畅overflow:auto;-
- css 一行(多行)文本超出... 等前端小知识
源大侠
1.css一行文本超出...overflow:hidden;text-overflow:ellipsis;white-space:nowrap;2.多行文本超出显示...display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;//根据实际情况修改overflow:hidden;3.IOS手机容器滚动条滑动不流畅ove
- java解析APK
3213213333332132
javaapklinux解析APK
解析apk有两种方法
1、结合安卓提供apktool工具,用java执行cmd解析命令获取apk信息
2、利用相关jar包里的集成方法解析apk
这里只给出第二种方法,因为第一种方法在linux服务器下会出现不在控制范围之内的结果。
public class ApkUtil
{
/**
* 日志对象
*/
private static Logger
- nginx自定义ip访问N种方法
ronin47
nginx 禁止ip访问
因业务需要,禁止一部分内网访问接口, 由于前端架了F5,直接用deny或allow是不行的,这是因为直接获取的前端F5的地址。
所以开始思考有哪些主案可以实现这样的需求,目前可实施的是三种:
一:把ip段放在redis里,写一段lua
二:利用geo传递变量,写一段
- mysql timestamp类型字段的CURRENT_TIMESTAMP与ON UPDATE CURRENT_TIMESTAMP属性
dcj3sjt126com
mysql
timestamp有两个属性,分别是CURRENT_TIMESTAMP 和ON UPDATE CURRENT_TIMESTAMP两种,使用情况分别如下:
1.
CURRENT_TIMESTAMP
当要向数据库执行insert操作时,如果有个timestamp字段属性设为
CURRENT_TIMESTAMP,则无论这
- struts2+spring+hibernate分页显示
171815164
Hibernate
分页显示一直是web开发中一大烦琐的难题,传统的网页设计只在一个JSP或者ASP页面中书写所有关于数据库操作的代码,那样做分页可能简单一点,但当把网站分层开发后,分页就比较困难了,下面是我做Spring+Hibernate+Struts2项目时设计的分页代码,与大家分享交流。
1、DAO层接口的设计,在MemberDao接口中定义了如下两个方法:
public in
- 构建自己的Wrapper应用
g21121
rap
我们已经了解Wrapper的目录结构,下面可是正式利用Wrapper来包装我们自己的应用,这里假设Wrapper的安装目录为:/usr/local/wrapper。
首先,创建项目应用
&nb
- [简单]工作记录_多线程相关
53873039oycg
多线程
最近遇到多线程的问题,原来使用异步请求多个接口(n*3次请求) 方案一 使用多线程一次返回数据,最开始是使用5个线程,一个线程顺序请求3个接口,超时终止返回 缺点 测试发现必须3个接
- 调试jdk中的源码,查看jdk局部变量
程序员是怎么炼成的
jdk 源码
转自:http://www.douban.com/note/211369821/
学习jdk源码时使用--
学习java最好的办法就是看jdk源代码,面对浩瀚的jdk(光源码就有40M多,比一个大型网站的源码都多)从何入手呢,要是能单步调试跟进到jdk源码里并且能查看其中的局部变量最好了。
可惜的是sun提供的jdk并不能查看运行中的局部变量
- Oracle RAC Failover 详解
aijuans
oracle
Oracle RAC 同时具备HA(High Availiablity) 和LB(LoadBalance). 而其高可用性的基础就是Failover(故障转移). 它指集群中任何一个节点的故障都不会影响用户的使用,连接到故障节点的用户会被自动转移到健康节点,从用户感受而言, 是感觉不到这种切换。
Oracle 10g RAC 的Failover 可以分为3种:
1. Client-Si
- form表单提交数据编码方式及tomcat的接受编码方式
antonyup_2006
JavaScripttomcat浏览器互联网servlet
原帖地址:http://www.iteye.com/topic/266705
form有2中方法把数据提交给服务器,get和post,分别说下吧。
(一)get提交
1.首先说下客户端(浏览器)的form表单用get方法是如何将数据编码后提交给服务器端的吧。
对于get方法来说,都是把数据串联在请求的url后面作为参数,如:http://localhost:
- JS初学者必知的基础
百合不是茶
js函数js入门基础
JavaScript是网页的交互语言,实现网页的各种效果,
JavaScript 是世界上最流行的脚本语言。
JavaScript 是属于 web 的语言,它适用于 PC、笔记本电脑、平板电脑和移动电话。
JavaScript 被设计为向 HTML 页面增加交互性。
许多 HTML 开发者都不是程序员,但是 JavaScript 却拥有非常简单的语法。几乎每个人都有能力将小的
- iBatis的分页分析与详解
bijian1013
javaibatis
分页是操作数据库型系统常遇到的问题。分页实现方法很多,但效率的差异就很大了。iBatis是通过什么方式来实现这个分页的了。查看它的实现部分,发现返回的PaginatedList实际上是个接口,实现这个接口的是PaginatedDataList类的对象,查看PaginatedDataList类发现,每次翻页的时候最
- 精通Oracle10编程SQL(15)使用对象类型
bijian1013
oracle数据库plsql
/*
*使用对象类型
*/
--建立和使用简单对象类型
--对象类型包括对象类型规范和对象类型体两部分。
--建立和使用不包含任何方法的对象类型
CREATE OR REPLACE TYPE person_typ1 as OBJECT(
name varchar2(10),gender varchar2(4),birthdate date
);
drop type p
- 【Linux命令二】文本处理命令awk
bit1129
linux命令
awk是Linux用来进行文本处理的命令,在日常工作中,广泛应用于日志分析。awk是一门解释型编程语言,包含变量,数组,循环控制结构,条件控制结构等。它的语法采用类C语言的语法。
awk命令用来做什么?
1.awk适用于具有一定结构的文本行,对其中的列进行提取信息
2.awk可以把当前正在处理的文本行提交给Linux的其它命令处理,然后把直接结构返回给awk
3.awk实际工
- JAVA(ssh2框架)+Flex实现权限控制方案分析
白糖_
java
目前项目使用的是Struts2+Hibernate+Spring的架构模式,目前已经有一套针对SSH2的权限系统,运行良好。但是项目有了新需求:在目前系统的基础上使用Flex逐步取代JSP,在取代JSP过程中可能存在Flex与JSP并存的情况,所以权限系统需要进行修改。
【SSH2权限系统的实现机制】
权限控制分为页面和后台两块:不同类型用户的帐号分配的访问权限是不同的,用户使
- angular.forEach
boyitech
AngularJSAngularJS APIangular.forEach
angular.forEach 描述: 循环对obj对象的每个元素调用iterator, obj对象可以是一个Object或一个Array. Iterator函数调用方法: iterator(value, key, obj), 其中obj是被迭代对象,key是obj的property key或者是数组的index,value就是相应的值啦. (此函数不能够迭代继承的属性.)
- java-谷歌面试题-给定一个排序数组,如何构造一个二叉排序树
bylijinnan
二叉排序树
import java.util.LinkedList;
public class CreateBSTfromSortedArray {
/**
* 题目:给定一个排序数组,如何构造一个二叉排序树
* 递归
*/
public static void main(String[] args) {
int[] data = { 1, 2, 3, 4,
- action执行2次
Chen.H
JavaScriptjspXHTMLcssWebwork
xwork 写道 <action name="userTypeAction"
class="com.ekangcount.website.system.view.action.UserTypeAction">
<result name="ssss" type="dispatcher">
- [时空与能量]逆转时空需要消耗大量能源
comsci
能源
无论如何,人类始终都想摆脱时间和空间的限制....但是受到质量与能量关系的限制,我们人类在目前和今后很长一段时间内,都无法获得大量廉价的能源来进行时空跨越.....
在进行时空穿梭的实验中,消耗超大规模的能源是必然
- oracle的正则表达式(regular expression)详细介绍
daizj
oracle正则表达式
正则表达式是很多编程语言中都有的。可惜oracle8i、oracle9i中一直迟迟不肯加入,好在oracle10g中终于增加了期盼已久的正则表达式功能。你可以在oracle10g中使用正则表达式肆意地匹配你想匹配的任何字符串了。
正则表达式中常用到的元数据(metacharacter)如下:
^ 匹配字符串的开头位置。
$ 匹配支付传的结尾位置。
*
- 报表工具与报表性能的关系
datamachine
报表工具birt报表性能润乾报表
在选择报表工具时,性能一直是用户关心的指标,但是,报表工具的性能和整个报表系统的性能有多大关系呢?
要回答这个问题,首先要分析一下报表的处理过程包含哪些环节,哪些环节容易出现性能瓶颈,如何优化这些环节。
一、报表处理的一般过程分析
1、用户选择报表输入参数后,报表引擎会根据报表模板和输入参数来解析报表,并将数据计算和读取请求以SQL的方式发送给数据库。
2、
- 初一上学期难记忆单词背诵第一课
dcj3sjt126com
wordenglish
what 什么
your 你
name 名字
my 我的
am 是
one 一
two 二
three 三
four 四
five 五
class 班级,课
six 六
seven 七
eight 八
nince 九
ten 十
zero 零
how 怎样
old 老的
eleven 十一
twelve 十二
thirteen
- 我学过和准备学的各种技术
dcj3sjt126com
技术
语言VB https://msdn.microsoft.com/zh-cn/library/2x7h1hfk.aspxJava http://docs.oracle.com/javase/8/C# https://msdn.microsoft.com/library/vstudioPHP http://php.net/manual/en/Html
- struts2中token防止重复提交表单
蕃薯耀
重复提交表单struts2中token
struts2中token防止重复提交表单
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 2015年7月12日 11:52:32 星期日
ht
- 线性查找二维数组
hao3100590
二维数组
1.算法描述
有序(行有序,列有序,且每行从左至右递增,列从上至下递增)二维数组查找,要求复杂度O(n)
2.使用到的相关知识:
结构体定义和使用,二维数组传递(http://blog.csdn.net/yzhhmhm/article/details/2045816)
3.使用数组名传递
这个的不便之处很明显,一旦确定就是不能设置列值
//使
- spring security 3中推荐使用BCrypt算法加密密码
jackyrong
Spring Security
spring security 3中推荐使用BCrypt算法加密密码了,以前使用的是md5,
Md5PasswordEncoder 和 ShaPasswordEncoder,现在不推荐了,推荐用bcrpt
Bcrpt中的salt可以是随机的,比如:
int i = 0;
while (i < 10) {
String password = "1234
- 学习编程并不难,做到以下几点即可!
lampcy
javahtml编程语言
不论你是想自己设计游戏,还是开发iPhone或安卓手机上的应用,还是仅仅为了娱乐,学习编程语言都是一条必经之路。编程语言种类繁多,用途各 异,然而一旦掌握其中之一,其他的也就迎刃而解。作为初学者,你可能要先从Java或HTML开始学,一旦掌握了一门编程语言,你就发挥无穷的想象,开发 各种神奇的软件啦。
1、确定目标
学习编程语言既充满乐趣,又充满挑战。有些花费多年时间学习一门编程语言的大学生到
- 架构师之mysql----------------用group+inner join,left join ,right join 查重复数据(替代in)
nannan408
right join
1.前言。
如题。
2.代码
(1)单表查重复数据,根据a分组
SELECT m.a,m.b, INNER JOIN (select a,b,COUNT(*) AS rank FROM test.`A` A GROUP BY a HAVING rank>1 )k ON m.a=k.a
(2)多表查询 ,
使用改为le
- jQuery选择器小结 VS 节点查找(附css的一些东西)
Everyday都不同
jquerycssname选择器追加元素查找节点
最近做前端页面,频繁用到一些jQuery的选择器,所以特意来总结一下:
测试页面:
<html>
<head>
<script src="jquery-1.7.2.min.js"></script>
<script>
/*$(function() {
$(documen
- 关于EXT
tntxia
ext
ExtJS是一个很不错的Ajax框架,可以用来开发带有华丽外观的富客户端应用,使得我们的b/s应用更加具有活力及生命力。ExtJS是一个用 javascript编写,与后台技术无关的前端ajax框架。因此,可以把ExtJS用在.Net、Java、Php等各种开发语言开发的应用中。
ExtJs最开始基于YUI技术,由开发人员Jack
- 一个MIT计算机博士对数学的思考
xjnine
Math
在过去的一年中,我一直在数学的海洋中游荡,research进展不多,对于数学世界的阅历算是有了一些长进。为什么要深入数学的世界?作为计算机的学生,我没有任何企图要成为一个数学家。我学习数学的目的,是要想爬上巨人的肩膀,希望站在更高的高度,能把我自己研究的东西看得更深广一些。说起来,我在刚来这个学校的时候,并没有预料到我将会有一个深入数学的旅程。我的导师最初希望我去做的题目,是对appe