데이터 베이스 MySQL 튜토리얼 在MySQL中根据规则生成随机密码_MySQL

在MySQL中根据规则生成随机密码_MySQL

Jun 01, 2016 pm 01:41 PM
저장 보안

bitsCN.com
在MySQL中根据规则生成随机密码 MySQL 5.0 以后的版本开始支持存储过程,存储过程具有壹致性、高效性和安全性。MySQL 5.0 之前的版本并不支持存储过程,然而随着 MySQL 技术的日趋完善,存储过程将在以后的项目中得到 广泛的应用。 在我的应用中,我需要在用户首次注册时为该帐号生成一个随机密码。所生成的密码必须满足一定的要求,这些要求由系统管理员进行配置。 我们提供了下面几个对密码的要求规则,这些规则可组合使用: 1- 要求大写字母 UPPERCASE                =====> 缩写 [U] 2- 要求小写字母 LOWERCASE               =====> 缩写 [L] 3- 要求使用数字 NUMBER                      =====> 缩写 [N] 4- 可以是任意字符 ANY_CHARACTER   ======> 缩写 [A] 5- 必须有非字母和数字的字符 NON_ALPHANUMERIC_CHARACTER =====> 缩写 [S] 因此我想通过创建一个动态函数 "RANDOM_PASSWORD" 来根据要求返回随机的密码。   系统管理员只需要传递所需密码的规则就会返回对应的随机密码。 例如要求如下: 首字符必须大写             ======> U 第二个字符必须小写       ======> L 第三个字符必须是数字    ======>N 第四个字符随意             ======>A 第五个字符必须是非字母和数字  ======>S 第六个字符必须是数字    ======> N     那么你可以使用 "ULNASN" 参数来获取随机密码。 所生成的密码程度跟传递的参数长度是一致的。在我们这个例子中生成的密码长度是 6。你可以使用下面的方法来调用这个函数: 1RANDOM_PASSWORD('ULNASN')在MySQL的控制台编写函数定义前,先要将数据库中可能已经存在的此函数定义删除,然后须将分隔符更改为$,其实我本想将分隔符改成#,后来发现没有成功,不知道是为什么,在命令行下删除 RANDOM_PASSWORD() 函数的定义与更改分隔符使用如下命令:   1mysql> DROP FUNCTION IF EXISTS RANDOM_PASSWORD;2mysql> delimiter $接下来可以编写该函数,经过我调试通过的源代码如下:  01CREATE FUNCTION RANDOM_PASSWORD (str VARCHAR(255))02RETURNS VARCHAR(255)03BEGIN04    DECLARE UPPER_CASE VARCHAR(26) DEFAULT 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';05    DECLARE LOWER_CASE VARCHAR(26) DEFAULT 'abcdefghijklmnopqrstuvwxyz';06    DECLARE NUMBERS VARCHAR(10) DEFAULT '0123456789';07    DECLARE TEMP_CHARACTER VARCHAR(255) DEFAULT '';08    DECLARE NON_ALPHANUMERIC_CHARACTERS VARCHAR(255) DEFAULT '~!@#$%^&*()_+-=`:;,.?/';09        DECLARE ALL_STRING VARCHAR(255) DEFAULT 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789~!@#$%^&*()_+-=`:;,.?/';10    DECLARE STR_LENGTH INT DEFAULT 0;11    DECLARE i INT DEFAULT 0;12    DECLARE RANDOM_CHARACTER CHAR(1) DEFAULT ' ';13    DECLARE PASSWORD_RETURNED VARCHAR(255) DEFAULT '';14     15    SET STR_LENGTH = CHAR_LENGTH(str);16     17    WHILE i select RANDOM_PASSWORD('ULNASN') PASSWORD;2    +----------+3| PASSWORD |4+----------+5| Bv1n`8   |6+----------+71 row in set (0.00 sec)在我这里将返回的随机密码是:Bv1n`8 当然,你运行的结果可能不一样,因为这是随机的。  作者 Bairrfhoinn bitsCN.com

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP5 및 PHP8의 성능 및 보안: 비교 및 ​​개선 PHP5 및 PHP8의 성능 및 보안: 비교 및 ​​개선 Jan 26, 2024 am 10:19 AM

PHP는 웹 애플리케이션 개발에 널리 사용되는 서버 측 스크립팅 언어입니다. 여러 버전으로 개발되었으며, 이 기사에서는 주로 PHP5와 PHP8의 비교에 대해 논의할 것이며 특히 성능 및 보안 향상에 중점을 둘 것입니다. 먼저 PHP5의 몇 가지 기능을 살펴보겠습니다. PHP5는 2004년에 출시되었으며 객체 지향 프로그래밍(OOP), 예외 처리, 네임스페이스 등과 같은 많은 새로운 기능과 기능을 도입했습니다. 이러한 기능은 PHP5를 더욱 강력하고 유연하게 만들어 개발자가 다음을 수행할 수 있게 해줍니다.

화웨이는 내년에 혁신적인 MED 스토리지 제품을 출시할 예정입니다. 랙 용량은 10PB를 초과하고 전력 소비량은 2kW 미만입니다. 화웨이는 내년에 혁신적인 MED 스토리지 제품을 출시할 예정입니다. 랙 용량은 10PB를 초과하고 전력 소비량은 2kW 미만입니다. Mar 07, 2024 pm 10:43 PM

이 웹사이트는 3월 7일 화웨이의 데이터 스토리지 제품 라인 사장인 Zhou Yuefeng 박사가 최근 MWC2024 컨퍼런스에 참석하여 웜 데이터(WarmData)와 콜드 데이터(ColdData)용으로 설계된 차세대 OceanStorArctic 자전 스토리지 솔루션을 구체적으로 시연했다고 보도했습니다. Huawei의 데이터 스토리지 제품 라인 사장 Zhou Yuefeng은 일련의 혁신적인 솔루션을 출시했습니다. 이미지 출처: 이 사이트에 첨부된 Huawei의 공식 보도 자료는 다음과 같습니다. 이 솔루션의 가격은 자기 테이프보다 20% 저렴하며, 전력 소비는 하드 디스크보다 90% 낮습니다. 해외 기술 매체인 blockandfiles에 따르면, Huawei 대변인은 자기전기 저장 솔루션에 대한 정보도 공개했습니다. Huawei의 자기전자 디스크(MED)는 자기 저장 매체의 주요 혁신입니다. 1세대 ME

Golang 개발의 보안 과제: 바이러스 생성에 악용되는 것을 방지하는 방법은 무엇입니까? Golang 개발의 보안 과제: 바이러스 생성에 악용되는 것을 방지하는 방법은 무엇입니까? Mar 19, 2024 pm 12:39 PM

Golang 개발의 보안 과제: 바이러스 생성에 악용되는 것을 방지하는 방법은 무엇입니까? 프로그래밍 분야에서 Golang이 광범위하게 적용됨에 따라 점점 더 많은 개발자가 Golang을 사용하여 다양한 유형의 응용 프로그램을 개발하는 것을 선택하고 있습니다. 그러나 다른 프로그래밍 언어와 마찬가지로 Golang 개발에는 보안 문제가 있습니다. 특히 Golang의 강력함과 유연성 덕분에 Golang은 잠재적인 바이러스 생성 도구로도 활용될 수 있습니다. 이 기사에서는 Golang 개발의 보안 문제를 조사하고 G를 방지하는 몇 가지 방법을 제공합니다.

우분투에서의 Git 설치 과정 우분투에서의 Git 설치 과정 Mar 20, 2024 pm 04:51 PM

Git은 빠르고 안정적이며 적응력이 뛰어난 분산 버전 제어 시스템입니다. 분산된 비선형 워크플로를 지원하도록 설계되어 모든 규모의 소프트웨어 개발 팀에 이상적입니다. 각 Git 작업 디렉터리는 모든 변경 사항에 대한 전체 기록을 보유하고 네트워크 액세스나 중앙 서버 없이도 버전을 추적할 수 있는 독립적인 저장소입니다. GitHub는 분산 개정 제어의 모든 기능을 제공하는 클라우드에 호스팅되는 Git 저장소입니다. GitHub는 클라우드에서 호스팅되는 Git 저장소입니다. CLI 도구인 Git과 달리 GitHub에는 웹 기반 그래픽 사용자 인터페이스가 있습니다. 이는 다른 개발자와 협력하고 스크립트 변경 사항을 추적하는 버전 제어에 사용됩니다.

Java 기능의 메모리 관리 기술과 보안 간의 관계는 무엇입니까? Java 기능의 메모리 관리 기술과 보안 간의 관계는 무엇입니까? May 02, 2024 pm 01:06 PM

Java의 메모리 관리에는 가비지 수집 및 참조 계산을 사용하여 메모리를 할당, 사용 및 회수하는 자동 메모리 관리가 포함됩니다. 효과적인 메모리 관리는 버퍼 오버플로, 와일드 포인터 및 메모리 누수를 방지하여 프로그램의 안전성을 향상시키므로 보안에 매우 중요합니다. 예를 들어 더 이상 필요하지 않은 개체를 적절하게 해제하면 메모리 누수를 방지할 수 있으므로 프로그램 성능이 향상되고 충돌이 방지됩니다.

win11은 바이러스 백신 소프트웨어를 설치해야 합니까? win11은 바이러스 백신 소프트웨어를 설치해야 합니까? Dec 27, 2023 am 09:42 AM

Win11에는 바이러스 백신 소프트웨어가 함께 제공됩니다. 일반적으로 바이러스 백신 효과는 매우 좋으며 설치할 필요가 없습니다. 그러나 유일한 단점은 바이러스가 필요한지 미리 알려주지 않고 먼저 제거된다는 것입니다. . 동의하면 다른 바이러스 백신 소프트웨어를 다운로드할 필요가 없습니다. win11에는 바이러스 백신 소프트웨어를 설치해야 합니까? 답변: 아니요. 일반적으로 win11에는 바이러스 백신 소프트웨어가 함께 제공되므로 추가 설치가 필요하지 않습니다. win11 시스템과 함께 제공되는 바이러스 백신 소프트웨어의 처리 방식이 마음에 들지 않으면 다시 설치할 수 있습니다. win11과 함께 제공되는 바이러스 백신 소프트웨어를 끄는 방법: 1. 먼저 설정을 입력하고 "개인 정보 보호 및 보안"을 클릭합니다. 2. 그런 다음 "창 보안 센터"를 클릭하십시오. 3. 그런 다음 "바이러스 및 위협 방지"를 선택합니다. 4. 마지막으로 끌 수 있습니다

민감한 데이터를 보호하기 위해 sessionStorage를 올바르게 사용하는 방법 민감한 데이터를 보호하기 위해 sessionStorage를 올바르게 사용하는 방법 Jan 13, 2024 am 11:54 AM

sessionStorage를 올바르게 사용하여 민감한 정보를 저장하려면 특정 코드 예제가 필요합니다. 웹 개발이든 모바일 애플리케이션 개발이든 사용자 로그인 자격 증명, ID 번호 등과 같은 민감한 정보를 저장하고 처리해야 하는 경우가 많습니다. 프런트엔드 개발에서는 sessionStorage를 사용하는 것이 일반적인 스토리지 솔루션입니다. 그러나 sessionStorage는 브라우저 기반 스토리지이기 때문에 저장된 민감한 정보가 악의적으로 접근 및 사용되지 않도록 몇 가지 보안 문제에 주의가 필요합니다.

C++ 컨테이너 라이브러리에 대한 반복자 안전 보장 C++ 컨테이너 라이브러리에 대한 반복자 안전 보장 Jun 05, 2024 pm 04:07 PM

C++ 컨테이너 라이브러리는 반복자의 안전성을 보장하기 위해 다음과 같은 메커니즘을 제공합니다. 1. 컨테이너 불변성 보장 2. 반복자 복사 3. 반복자 범위 5. 예외 안전성

See all articles