chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

SpringBoot采用JsonSerializer和Aop實現(xiàn)可控制的數(shù)據(jù)脫敏

jf_ro2CN3Fa ? 來源:芋道源碼 ? 2023-11-06 16:15 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群


1 起因

最近在寫一個功能,對用戶敏感的數(shù)據(jù)進行脫敏,在網(wǎng)上看一圈基本上都是全局范圍的,我覺得應(yīng)該更加靈活,在不同場景,不同業(yè)務(wù)下進行脫敏更加合適。

JsonSerializer介紹就參考這位大佬的

https://juejin.cn/post/6872636051237240846

aop介紹參考這位大佬的

https://juejin.cn/post/6844903575441637390

基于 Spring Boot + MyBatis Plus + Vue & Element 實現(xiàn)的后臺管理系統(tǒng) + 用戶小程序,支持 RBAC 動態(tài)權(quán)限、多租戶、數(shù)據(jù)權(quán)限、工作流、三方登錄、支付、短信、商城等功能

  • 項目地址:https://github.com/YunaiV/ruoyi-vue-pro
  • 視頻教程:https://doc.iocoder.cn/video/

2 初步嘗試

枚舉類

/**
*敏感信息枚舉類
*
**/
publicenumPrivacyTypeEnum{

/**
*自定義
*/
CUSTOMER,
/**
*用戶名,張*三,李*
*/
CHINESE_NAME,
/**
*身份證號,110110********1234
*/
ID_CARD,
/**
*座機號,****1234
*/
FIXED_PHONE,
/**
*手機號,176****1234
*/
MOBILE_PHONE,
/**
*地址,北京********
*/
ADDRESS,
/**
*電子郵件,s*****o@xx.com
*/
EMAIL,
/**
*銀行卡,622202************1234
*/
BANK_CARD,
/**
*密碼,永遠(yuǎn)是******,與長度無關(guān)
*/
PASSWORD,
/**
*密鑰,永遠(yuǎn)是******,與長度無關(guān)
*/
KEY

}

注解

@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD})//作用于字段上
@JacksonAnnotationsInside//表示自定義自己的注解PrivacyEncrypt
@JsonSerialize(using=PrivacySerialize.class)//該注解使用序列化的方式
public@interfacePrivacyEncrypt{

/**
*脫敏數(shù)據(jù)類型,非Customer時,將忽略refixNoMaskLen和suffixNoMaskLen和maskStr
*/
PrivacyTypeEnumtype()defaultPrivacyTypeEnum.CUSTOMER;

/**
*前置不需要打碼的長度
*/
intprefixNoMaskLen()default0;

/**
*后置不需要打碼的長度
*/
intsuffixNoMaskLen()default0;

/**
*用什么打碼
*/
StringmaskStr()default"*";

}

序列化類

publicclassPrivacySerializeextendsJsonSerializer<String>implementsContextualSerializer{
publicstaticfinalLoggerlogger=LoggerFactory.getLogger(PrivacySerialize.class);
privatePrivacyTypeEnumtype;

privateIntegerprefixNoMaskLen;

privateIntegersuffixNoMaskLen;

privateStringmaskStr;

publicPrivacySerialize(PrivacyTypeEnumtype,IntegerprefixNoMaskLen,IntegersuffixNoMaskLen,StringmaskStr){
this.type=type;
this.prefixNoMaskLen=prefixNoMaskLen;
this.suffixNoMaskLen=suffixNoMaskLen;
this.maskStr=maskStr;
}
publicPrivacySerialize(){
}

@Override
publicvoidserialize(Stringorigin,JsonGeneratorjsonGenerator,SerializerProviderserializerProvider)throwsIOException{
if(StringUtils.isNotBlank(origin)&&null!=type){
switch(type){
caseCHINESE_NAME:
jsonGenerator.writeString(DesensitizedUtils.chineseName(origin));
break;
caseID_CARD:
jsonGenerator.writeString(DesensitizedUtils.idCardNum(origin));
break;
caseFIXED_PHONE:
jsonGenerator.writeString(DesensitizedUtils.fixedPhone(origin));
break;
caseMOBILE_PHONE:
jsonGenerator.writeString(DesensitizedUtils.mobilePhone(origin));
break;
caseADDRESS:
jsonGenerator.writeString(DesensitizedUtils.address(origin));
break;
caseEMAIL:
jsonGenerator.writeString(DesensitizedUtils.email(origin));
break;
caseBANK_CARD:
jsonGenerator.writeString(DesensitizedUtils.bankCard(origin));
break;
casePASSWORD:
jsonGenerator.writeString(DesensitizedUtils.password(origin));
break;
caseKEY:
jsonGenerator.writeString(DesensitizedUtils.key(origin));
break;
caseCUSTOMER:
jsonGenerator.writeString(DesensitizedUtils.desValue(origin,prefixNoMaskLen,suffixNoMaskLen,maskStr));
break;
default:
thrownewIllegalArgumentException("Unknowsensitivetypeenum"+type);
}
}else{
jsonGenerator.writeString("");
}

}

@Override
publicJsonSerializercreateContextual(SerializerProviderserializerProvider,BeanPropertybeanProperty)throwsJsonMappingException{
if(beanProperty!=null){
if(Objects.equals(beanProperty.getType().getRawClass(),String.class)){
PrivacyEncryptencrypt=beanProperty.getAnnotation(PrivacyEncrypt.class);
if(encrypt==null){
encrypt=beanProperty.getContextAnnotation(PrivacyEncrypt.class);
}
if(encrypt!=null){
returnnewPrivacySerialize(encrypt.type(),encrypt.prefixNoMaskLen(),
encrypt.suffixNoMaskLen(),encrypt.maskStr());
}
}
returnserializerProvider.findValueSerializer(beanProperty.getType(),beanProperty);
}
returnserializerProvider.findNullValueSerializer(null);
}
}

脫敏工具類

/**
*脫敏工具類
*
**/
publicclassDesensitizedUtils{

/**
*對字符串進行脫敏操作
*@paramorigin原始字符串
*@paramprefixNoMaskLen左側(cè)需要保留幾位明文字段
*@paramsuffixNoMaskLen右側(cè)需要保留幾位明文字段
*@parammaskStr用于遮罩的字符串,如'*'
*@return脫敏后結(jié)果
*/
publicstaticStringdesValue(Stringorigin,intprefixNoMaskLen,intsuffixNoMaskLen,StringmaskStr){
if(origin==null){
returnnull;
}

StringBuildersb=newStringBuilder();
for(inti=0,n=origin.length();iif(icontinue;
}
if(i>(n-suffixNoMaskLen-1)){
sb.append(origin.charAt(i));
continue;
}
sb.append(maskStr);
}
returnsb.toString();
}

/**
*【中文姓名】只顯示最后一個漢字,其他隱藏為星號,比如:**夢
*@paramfullName姓名
*@return結(jié)果
*/
publicstaticStringchineseName(StringfullName){
if(fullName==null){
returnnull;
}
returndesValue(fullName,0,1,"*");
}

/**
*【身份證號】顯示前六位,四位,其他隱藏。共計18位或者15位,比如:340304*******1234
*@paramid身份證號碼
*@return結(jié)果
*/
publicstaticStringidCardNum(Stringid){
returndesValue(id,6,4,"*");
}

/**
*【固定電話】后四位,其他隱藏,比如****1234
*@paramnum固定電話
*@return結(jié)果
*/
publicstaticStringfixedPhone(Stringnum){
returndesValue(num,0,4,"*");
}

/**
*【手機號碼】前三位,后四位,其他隱藏,比如135****6810
*@paramnum手機號碼
*@return結(jié)果
*/
publicstaticStringmobilePhone(Stringnum){
returndesValue(num,3,4,"*");
}

/**
*【地址】只顯示到地區(qū),不顯示詳細(xì)地址,比如:北京市海淀區(qū)****
*@paramaddress地址
*@return結(jié)果
*/
publicstaticStringaddress(Stringaddress){
returndesValue(address,6,0,"*");
}

/**
*【電子郵箱郵箱前綴僅顯示第一個字母,前綴其他隱藏,用星號代替,@及后面的地址顯示,比如:d**@126.com
*@paramemail電子郵箱
*@return結(jié)果
*/
publicstaticStringemail(Stringemail){
returnemail.replaceAll("(w?)(w+)(w)(@w+.[a-z]+(.[a-z]+)?)","$1****$3$4");

}

/**
*【銀行卡號】前六位,后四位,其他用星號隱藏每位1個星號,比如:622260**********1234
*@paramcardNum銀行卡號
*@return結(jié)果
*/
publicstaticStringbankCard(StringcardNum){
returndesValue(cardNum,6,4,"*");
}

/**
*【密碼】密碼的全部字符都用*代替,比如:******
*@parampassword密碼
*@return結(jié)果
*/
publicstaticStringpassword(Stringpassword){
if(password==null){
returnnull;
}
return"******";
}

/**
*【密鑰】密鑰除了最后三位,全部都用*代替,比如:***xdS脫敏后長度為6,如果明文長度不足三位,則按實際長度顯示,剩余位置補*
*@paramkey密鑰
*@return結(jié)果
*/
publicstaticStringkey(Stringkey){
if(key==null){
returnnull;
}
intviewLength=6;
StringBuildertmpKey=newStringBuilder(desValue(key,0,3,"*"));
if(tmpKey.length()>viewLength){
returntmpKey.substring(tmpKey.length()-viewLength);
}
elseif(tmpKey.length()intbuffLength=viewLength-tmpKey.length();
for(inti=0;i0,"*");
}
returntmpKey.toString();
}
else{
returntmpKey.toString();
}
}

}

注解使用

d20e65cc-7c44-11ee-939d-92fbcf53809c.pngd2406482-7c44-11ee-939d-92fbcf53809c.png

的確實現(xiàn)了數(shù)據(jù)脫敏,但是有個問題現(xiàn)在的脫敏針對的是 只要對該實體類進行了使用返回的接口,中的數(shù)據(jù)都會進行脫敏,在有些場景下是不需要的,所以說要進行改進。

基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 實現(xiàn)的后臺管理系統(tǒng) + 用戶小程序,支持 RBAC 動態(tài)權(quán)限、多租戶、數(shù)據(jù)權(quán)限、工作流、三方登錄、支付、短信、商城等功能

  • 項目地址:https://github.com/YunaiV/yudao-cloud
  • 視頻教程:https://doc.iocoder.cn/video/

3 第二版改進

我的思路是在該實體類中在繼承一個 父類其中定義一個字段,使其作為是否進行脫敏的開關(guān),并且該實體類字段不參與序列化 脫敏控制類

publicclassDataMaskKeyimplementsSerializable{
//不進行序列化,設(shè)置key來進行過濾的把控,默認(rèn)不開啟
privatetransientBooleanisPrivacyKey=false;

publicBooleangetPrivacyKey(){
returnisPrivacyKey;
}

publicvoidsetPrivacyKey(BooleanprivacyKey){
isPrivacyKey=privacyKey;
}
}

更新之后的序列化類

思路就是通過反射獲取,該成員的屬性,因為不知道會繼承多少,所以要進行遞歸查找需要的字段

publicclassPrivacySerializeextendsJsonSerializer<String>implementsContextualSerializer{
publicstaticfinalLoggerlogger=LoggerFactory.getLogger(PrivacySerialize.class);
privatePrivacyTypeEnumtype;

privateIntegerprefixNoMaskLen;

privateIntegersuffixNoMaskLen;

privateStringmaskStr;

publicPrivacySerialize(PrivacyTypeEnumtype,IntegerprefixNoMaskLen,IntegersuffixNoMaskLen,StringmaskStr){
this.type=type;
this.prefixNoMaskLen=prefixNoMaskLen;
this.suffixNoMaskLen=suffixNoMaskLen;
this.maskStr=maskStr;
}
publicPrivacySerialize(){
}

@Override
publicvoidserialize(Stringorigin,JsonGeneratorjsonGenerator,SerializerProviderserializerProvider)throwsIOException{
booleanflag=false;
//反射獲取對象
ObjectcurrentValue=jsonGenerator.getOutputContext().getCurrentValue();
//反射獲取class
ClassaClass=jsonGenerator.getOutputContext().getCurrentValue().getClass();
ListfieldList=getFieldList(aClass);
for(Fieldfield:fieldList){
//開始反射獲取
Stringname=field.getName();
if("isPrivacyKey".equals(name)){
try{
//進行重新賦值
flag=(boolean)field.get(currentValue);
}catch(IllegalAccessExceptione){
e.printStackTrace();
}
}
}
//反射進行進行開關(guān)判定
if(flag){
//logger.info("進行脫敏處理");
if(StringUtils.isNotBlank(origin)&&null!=type){
switch(type){
caseCHINESE_NAME:
jsonGenerator.writeString(DesensitizedUtils.chineseName(origin));
break;
caseID_CARD:
jsonGenerator.writeString(DesensitizedUtils.idCardNum(origin));
break;
caseFIXED_PHONE:
jsonGenerator.writeString(DesensitizedUtils.fixedPhone(origin));
break;
caseMOBILE_PHONE:
jsonGenerator.writeString(DesensitizedUtils.mobilePhone(origin));
break;
caseADDRESS:
jsonGenerator.writeString(DesensitizedUtils.address(origin));
break;
caseEMAIL:
jsonGenerator.writeString(DesensitizedUtils.email(origin));
break;
caseBANK_CARD:
jsonGenerator.writeString(DesensitizedUtils.bankCard(origin));
break;
casePASSWORD:
jsonGenerator.writeString(DesensitizedUtils.password(origin));
break;
caseKEY:
jsonGenerator.writeString(DesensitizedUtils.key(origin));
break;
caseCUSTOMER:
jsonGenerator.writeString(DesensitizedUtils.desValue(origin,prefixNoMaskLen,suffixNoMaskLen,maskStr));
break;
default:
thrownewIllegalArgumentException("Unknowsensitivetypeenum"+type);
}
}else{
jsonGenerator.writeString("");
}
}else{
//logger.info("不進行脫敏處理");
jsonGenerator.writeString(origin);
}

}

@Override
publicJsonSerializercreateContextual(SerializerProviderserializerProvider,BeanPropertybeanProperty)throwsJsonMappingException{
if(beanProperty!=null){
if(Objects.equals(beanProperty.getType().getRawClass(),String.class)){
PrivacyEncryptencrypt=beanProperty.getAnnotation(PrivacyEncrypt.class);
if(encrypt==null){
encrypt=beanProperty.getContextAnnotation(PrivacyEncrypt.class);
}
if(encrypt!=null){
returnnewPrivacySerialize(encrypt.type(),encrypt.prefixNoMaskLen(),
encrypt.suffixNoMaskLen(),encrypt.maskStr());
}
}
returnserializerProvider.findValueSerializer(beanProperty.getType(),beanProperty);
}
returnserializerProvider.findNullValueSerializer(null);
}

privateListgetFieldList(Classclazz){
if(null==clazz){
returnnull;
}
ListfieldList=newArrayList<>();
//遞歸查找需求的字段
ClassaClass=ClassRecursionUtils.getClass(clazz,"isPrivacyKey");
Field[]declaredFields=aClass.getDeclaredFields();
for(Fieldfield:declaredFields){
if(field!=null){
//設(shè)置屬性的可訪問性
field.setAccessible(true);
//過濾靜態(tài)
if(Modifier.isStatic(field.getModifiers())){
continue;
}
Stringname=field.getName();
//過濾非布爾類型
Classtype=field.getType();
//并且只添加isPrivacyKey
if(type.isAssignableFrom(Boolean.class)&&"isPrivacyKey".equals(name)){
fieldList.add(field);
}
}
}
returnfieldList;
}

}

遞歸工具類

publicclassClassRecursionUtils{
publicstaticClassgetClass(Classc,StringfieldName){
if(c!=null&&!hasField(c,fieldName)){
returngetClass(c.getSuperclass(),fieldName);
}
returnc;
}

publicstaticbooleanhasField(Classc,StringfieldName){
Field[]fields=c.getDeclaredFields();
for(Fieldf:fields){
if(fieldName.equals(f.getName())){
returntrue;
}
}
returnfalse;
}
}

現(xiàn)在只需要在進行實體類 封裝數(shù)據(jù)時,在進行手動set即可

4 最終方案

在上述情況下可以實現(xiàn) 手動控制是否在某些場景下的脫敏,但是需要對原來的代碼進行修改,我覺得不友好,所以采用aop的形式進行控制

項目的返回類型基本上為兩種

  • 實體類作為返回
  • 分頁返回

aop注解

@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD})//作用于方法上
public@interfacePrivacyKeyAnnotation{

/**
*是否啟用序列化脫敏默認(rèn)開啟
*/
booleanisKey()defaulttrue;

/**
*是否為PageInfo(分頁對象)
*/
booleanisPageKey()defaultfalse;
}

aop類

@Component
@Aspect
publicclassPrivacyKeyAspect{
publicstaticfinalLoggerlogger=LoggerFactory.getLogger(PrivacyKeyAspect.class);

/**
*@Description:環(huán)繞通知包含此注解的
*@param:ProceedingJoinPointjoinPoint
*@return:Object
*/
@Around(value="@annotation("aop注解地址xxxxx")")
publicObjectrepeatSub(ProceedingJoinPointjoinPoint)throwsThrowable{
returnjoinPoint.proceed();
}

/**
*@Description:后置通知
*/
@AfterReturning(value="@annotation("aop注解地址")",returning="result")
publicvoidsetPrivacyKeyType(JoinPointjoinPoint,Objectresult)throwsThrowable{
//進行注解值獲取
MethodSignaturesignature=(MethodSignature)joinPoint.getSignature();
Methodmethod=signature.getMethod();
//是否開啟脫敏
booleanflag=method.getDeclaredAnnotation(PrivacyKeyAnnotation.class).isKey();
//是否對分頁進行脫敏
booleanstatus=method.getDeclaredAnnotation(PrivacyKeyAnnotation.class).isPageKey();
if(!status){
//進行返回值反射
ClassaClass=ClassRecursionUtils.getClass(result.getClass(),"isPrivacyKey");
if(null!=aClass){
setFieldMethod(result,flag,aClass);
}
}else{
//反射分頁page
//反射list類型
Parameter[]parameters=signature.getMethod().getParameters();
//泛型名稱
Stringname=parameters[0].getName();
//泛型class
Classtype=parameters[0].getType();
//包名
StringtypeName=type.getName();
PropertyDescriptor[]ps=Introspector.getBeanInfo(result.getClass(),Object.class).getPropertyDescriptors();
for(PropertyDescriptorprop:ps){
if(prop.getPropertyType().isAssignableFrom(List.class)){//List集合類型
Objectobj=result.getClass().getMethod(prop.getReadMethod().getName()).invoke(result);
if(obj!=null){
ListlistObj=(List)obj;
for(Objectnext:listObj){
ClassclassObj=Class.forName(typeName);
//獲取成員變量
ClasskeyClass=ClassRecursionUtils.getClass(classObj,"isPrivacyKey");
setFieldMethod(next,flag,keyClass);
}
}

}
}
}
}

/**
*內(nèi)容填充
*/
privatevoidsetFieldMethod(Objectresult,booleanflag,ClassaClass)throwsIllegalAccessException{
Field[]declaredFields=aClass.getDeclaredFields();
for(Fieldfield:declaredFields){
//設(shè)置屬性的可訪問性
field.setAccessible(true);
//只獲取isPrivacyKey
Stringname=field.getName();
//過濾非布爾類型
Classtype=field.getType();
//并且只添加isPrivacyKey
if(type.isAssignableFrom(Boolean.class)&&"isPrivacyKey".equals(name)){
//重新寫入
field.set(result,flag);
}
}
}
}

使用 在service implement類方法上寫入

最后,另一種實現(xiàn)方式,可以參考:

https://juejin.cn/post/7242145254057410615


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • AOP
    AOP
    +關(guān)注

    關(guān)注

    0

    文章

    41

    瀏覽量

    11402
  • 數(shù)據(jù)權(quán)限

    關(guān)注

    0

    文章

    4

    瀏覽量

    6153
  • SpringBoot
    +關(guān)注

    關(guān)注

    0

    文章

    175

    瀏覽量

    550

原文標(biāo)題:SpringBoot 采用 JsonSerializer 和 Aop 實現(xiàn)可控制的數(shù)據(jù)脫敏

文章出處:【微信號:芋道源碼,微信公眾號:芋道源碼】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    ?Texas Instruments AWR1843AOP汽車?yán)走_(dá)傳感器數(shù)據(jù)手冊摘要

    Texas Instruments AWR1843AOP汽車?yán)走_(dá)傳感器是封裝天線器件,在76GHz至81GHz頻段內(nèi)工作。AWR1843AOP采用TI’的低功耗45nm RFCMOS工藝,在微型外形中
    的頭像 發(fā)表于 09-26 14:52 ?246次閱讀
    ?Texas Instruments AWR1843<b class='flag-5'>AOP</b>汽車?yán)走_(dá)傳感器<b class='flag-5'>數(shù)據(jù)</b>手冊摘要

    ?基于AWR1843AOPEVM評估模塊的毫米波雷達(dá)技術(shù)解析

    器件,在76GHz至81GHz頻段內(nèi)工作。AWR1843AOP采用TI’的低功耗45nm RFCMOS工藝,在微型外形中實現(xiàn)超高集成度。
    的頭像 發(fā)表于 09-22 11:43 ?333次閱讀
    ?基于AWR1843AOPEVM評估模塊的毫米波雷達(dá)技術(shù)解析

    SAP 數(shù)據(jù)脫敏工具:SNP TDO如何滿足新頒敏感信息政策要求

    面對我國新頒《數(shù)據(jù)安全法》《個保法》敏感信息政策,本篇文章將詳細(xì)解答企業(yè)數(shù)據(jù)合規(guī)三大剛需:國家機密防護、商業(yè)數(shù)據(jù)保護、個人隱私脫敏
    的頭像 發(fā)表于 08-19 09:49 ?193次閱讀

    可控硅光耦怎么使用?

    自動控制系統(tǒng)中,可作為大功率驅(qū)動器件,實現(xiàn)用小功率控件控制大功率設(shè)備。它在交直流電機調(diào)速系統(tǒng)、調(diào)功系統(tǒng)及隨動系統(tǒng)中得到了廣泛的應(yīng)用。而可控硅光耦(SCR光耦)憑借其高隔
    的頭像 發(fā)表于 07-15 10:12 ?502次閱讀
    <b class='flag-5'>可控</b>硅光耦怎么使用?

    MOC3021控制雙向可控硅關(guān)斷

    在我的這個電路圖里,可控硅一直處于開啟狀態(tài),沒有給單片機信號,試著換一下可控硅的方向,也沒有效果。請各位大佬幫忙看一下是不是電路圖那里出問題了。
    發(fā)表于 04-21 15:46

    可控硅的控制奧秘:依賴直流還是交流?

    。它的主要功能是控制電流的通過,從而實現(xiàn)對電路的調(diào)節(jié)和控制。可控硅的工作原理和控制方式是理解其應(yīng)用和性能的關(guān)鍵。
    的頭像 發(fā)表于 04-03 11:59 ?1059次閱讀
    <b class='flag-5'>可控</b>硅的<b class='flag-5'>控制</b>奧秘:依賴直流還是交流?

    托卡馬克裝置:探索可控核聚變的前沿利器

    、PSM高壓電源系統(tǒng) ▌電源效率高達(dá)97%以上; ▌具備自動閉環(huán)控制功能,系統(tǒng)能夠自動調(diào)節(jié)PSM模塊的開通個數(shù),實現(xiàn)精確的輸出電壓調(diào)節(jié); ▌采用特殊設(shè)計減少輸出電壓紋波; ▌支持穩(wěn)態(tài)和脈沖兩種工作模式
    發(fā)表于 03-10 18:56

    三相可控硅整流模塊怎么控制電壓大小

    三相可控硅整流模塊是一種電力電子設(shè)備,它利用可控硅(也稱為晶閘管)作為核心元件,通過控制其導(dǎo)通狀態(tài)來將交流電轉(zhuǎn)換為直流電,并實現(xiàn)對輸出電壓的調(diào)節(jié)。 一、三相
    的頭像 發(fā)表于 02-01 11:24 ?2148次閱讀

    請問LDC1000的電感輸出數(shù)據(jù)速率是否可控?

    請問LDC1000 的電感輸出數(shù)據(jù)速率 是否可控。是取決于寫入寄存器的最小諧振頻率,還是由實際的諧振頻率決定?!
    發(fā)表于 01-15 08:28

    可控硅的控制奧秘:依賴直流還是交流?

    可控硅是一種重要的半導(dǎo)體器件,通過控制極的觸發(fā)信號實現(xiàn)對電流的控制。它可以在直流和交流電路中應(yīng)用,分別用于開關(guān)、調(diào)節(jié)、調(diào)光等功能。直流控制
    的頭像 發(fā)表于 01-10 15:44 ?2662次閱讀
    <b class='flag-5'>可控</b>硅的<b class='flag-5'>控制</b>奧秘:依賴直流還是交流?

    BT131可控硅參數(shù)

    BT131可控硅是一種常用的半導(dǎo)體器件,具有可控性強、穩(wěn)定性好等特點,廣泛應(yīng)用于電力電子、自動化控制、照明等領(lǐng)域。
    的頭像 發(fā)表于 01-04 10:52 ?5946次閱讀
    BT131<b class='flag-5'>可控</b>硅參數(shù)

    可控硅在光伏逆變器中的應(yīng)用

    通與截止,實現(xiàn)對電能形式的轉(zhuǎn)換。具體來說,當(dāng)可控硅接收到適當(dāng)?shù)?b class='flag-5'>控制信號時,其內(nèi)部的PN結(jié)會發(fā)生變化,從而允許或阻止電流的流動。 二、可控硅在光伏逆變器中的應(yīng)用 電能轉(zhuǎn)換 : 在光伏逆變
    的頭像 發(fā)表于 12-04 10:49 ?1770次閱讀

    可控硅在電動機控制中的應(yīng)用

    可控硅在電動機控制中的應(yīng)用十分廣泛,主要體現(xiàn)在以下幾個方面: 一、電動機調(diào)速控制 可控硅驅(qū)動器可以根據(jù)控制信號調(diào)節(jié)提供給電動機的電壓或者電流
    的頭像 發(fā)表于 12-04 10:34 ?2288次閱讀

    可控硅的工作原理 可控硅與晶閘管的區(qū)別

    硅的工作原理可以簡述為:當(dāng)外加電壓由零向正方向變化時,P-N結(jié)兩端就產(chǎn)生正向壓降而形成控制電流;當(dāng)外加電壓由正方向變?yōu)樨?fù)值時,P-N結(jié)兩端出現(xiàn)較大正值而產(chǎn)生控制電流。這種利用注入的少數(shù)載流子的導(dǎo)電性直接改變PN結(jié)電阻值以控制輸出
    的頭像 發(fā)表于 12-04 10:31 ?3145次閱讀

    可控硅型號怎樣識別

    可控硅,也被稱為晶閘管(Thyristor),是一種四層三端半導(dǎo)體器件,主要用于電力電子領(lǐng)域,如交流/直流轉(zhuǎn)換、電機控制、電源調(diào)節(jié)等。可控硅型號的識別通常涉及以下幾個方面: 制造商代碼 :不同制造商
    的頭像 發(fā)表于 10-21 09:51 ?3918次閱讀