起因是想在服务器上安装SVN Server,选择的是SVN Server,这软件好像只支持http(s)协议,没有SVN协议,好吧,就不折腾了。在安装时选择端口号时又凌乱了,不想暴露那么多端口号,就打算用IIS的反射代理来实现。

这里记录一下设置IIS反向代理的操作步骤:

  • 先安装以下两个软件:
    Application Request Routing
    URL Rewrite
    其实你安装第一个ARR时时,会自动安装Url Rewrite,因为它依赖后者。
  • 在IIS里设置Application Request Routing Cache,打开Server Proxy Setting,选择以下:
    Enable Proxy -> YES
    Keep alive -> YES
    Reverse rewrite host in response headers -> NO
  • 在IIS里新建一个网站
  • 在网站中设置URL Rewrite:

      <rule name="svn" stopProcessing="true">
          <match url="(.*)" />
          <action type="Rewrite" url="http://localhost:81/{R:1}" />
      </rule>
    

注意:

  • 以下方法仅适用于没有主从同步的情况下清理日志
  • 需要有相关权限

*清理5天前的binlog

PURGE MASTER LOGS BEFORE DATE_SUB( NOW( ),INTERVAL 5 DAY)'

*重置binlog

reset master;

高版本,比如:

  • Visual Studio 2019
  • Visual Studio 2022
  • ...

低版本,比如:

  • .Net Framework 4.0
  • .Net Framework 4.5
  • ...

这个问题经常遇到,一般是在重新系统后都要来一遍,长时间不操作,经常忘记目录,这里记录操作步骤:

  • 在NuGet网站搜索:Microsoft.NETFramework.ReferenceAssemblies。
  • 下载自己需要的.Net Framework目标包,需要哪个版本就下载哪个版本的包文件。
  • 解压下载的.nupkg文件
  • 将解压出来的build.NETFramework目录下的指定版本目录复制到C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework\.NETFramework

  • 打开网址: chrome://sync-internals/
  • 点击 Disable Sync (Clear Data)
  • 点击 Request Start

数字枚举

  • 默认情况下就是数字枚举

    enum Gender {
      Male,
      Female
    }
    
    console.log(Gender.Male);
    console.log(Gender.Female);
  • 数字枚举注意点:

    • 数字枚举的取值默认从 0 开始递增

      enum Gender {
       Male,
       Female
      }
      
      console.log(Gender.Male);
      console.log(Gender.Female);
    • 数字枚举的取值可以是字面量, 也可以是常量, 也可以是计算的结果

      • 字面量:

        enum Gender {
        Male = 1,
        Female
        }
        
        console.log(Gender.Male);
        console.log(Gender.Female);
      • 常量,如果使用常量给前面的枚举值赋值了, 那么后面的枚举值也需要手动的赋值:

        const num = 666;
        
        enum Gender {
        Male = num,
        Female = 1
        }
        
        console.log(Gender.Male);
        console.log(Gender.Female);
      • 计算的结果,如果使用计算结果给前面的枚举值赋值了, 那么后面的枚举值也需要手动的赋值:

        function getNum() {
        return 888;
        }
        
        enum Gender {
        Male = getNum(),
        Female = 1
        }
        
        console.log(Gender.Male);
        console.log(Gender.Female);

枚举反向映射

  • 可以根据枚举值获取到原始值

    enum Gender {
      Male,
      Female
    }
    
    console.log(Gender.Male);
  • 也可以根据原始值获取到枚举值

    enum Gender {
      Male,
      Female
    }
    
    console.log(Gender[0]);

字符串枚举

  • 如果使用字符串给前面的枚举值赋值了, 那么后面的枚举值也必须手动赋值

    enum Gender {
      Male = 'www.it6666.top',
      Female = 'BNTang'
    }
    
    console.log(Gender.Male);
    console.log(Gender.Female);
  • 字符串枚举注意点

    • 如果使用字符串给前面的枚举值赋值了, 那么后面的枚举值也必须手动赋值上面已经介绍了
    • 和数字枚举不一样, 字符串枚举不能使用常量或者计算结果给枚举值赋值
    • 虽然字符串枚举不能够使用常量或者计算结果给枚举值赋值, 但是它可以使用内部的其它枚举值来赋值
    enum Gender {
      Male = 'BNTang',
      Yao = Male
    }
    
    console.log(Gender.Male);
    console.log(Gender.Yao);

异构枚举

  • 枚举中既包含数字又包含字符串, 我们就称之为 异构枚举

    enum Gender {
      Male = 6,
      Female = 'nv'
    }
    
    console.log(Gender.Male);
    console.log(Gender.Female);
  • 注意点:如果是字符串枚举, 那么无法通过原始值获取到枚举值:

    enum Gender {
      Male = 6,
      Female = 'nv'
    }
    
    console.log(Gender['nv']);
    console.log(Gender);