키 포인트
스토리 DAO는 OpenZeppelin의 자체 계약을 사용하여 소유자 만 관리 기능을 수행 할 수 있도록하여 DAPP 운영에 대한 보안 및 제어를 향상시킵니다. 스토리 DAO 계약에는 조정 가능한 수수료 및 기간 매개 변수가 있으며 승인되지 않은 변경을 방지하기 위해 보안 조치가 장착되어 소유자 만 중요한 설정을 수정할 수 있습니다.
스토리의 화이트리스트 관리는 발신자의 기여에 따라 자동 및 조건부 액세스를 허용하는 유료 기능을 통해 구현됩니다.-
스토리 DAO의 배포 프로세스는 송로 버섯으로 단순화되며 특정 마이그레이션 스크립트 및 구성으로 개발 환경에서 생산 환경으로 원활한 전환을 촉진합니다. -
이 튜토리얼 시리즈의 세 번째 부분은 이더 리움을 사용하여 DAPP를 구축하는 것을 설명합니다. 여기서 Token을 Ethereum Test Network Rinkeby에 구축하고 배포합니다. 이 섹션에서는 스토리 DAO 코드를 쓰기 시작합니다. - 계약 개요 새로운 계약을 만들어 봅시다. 스토리 데어 (STORYDAO.SOL)는 다음과 같이있다.
- 우리는 안전한 계산을 다시하기 위해 Safemath를 가져 오지만 이번에는 Zeppelin의 자체 계약을 사용하여 누군가가 스토리를 "소유"하고 특정 관리자 전용 기능을 수행 할 수 있습니다. 간단히 말해서, 우리의 스토리 데이는 계약이 어떻게 작동하는지 이해하기에 충분합니다.
-
만이 함수에 추가되면 함수의 본문이 _가 위치한 위치에 붙여지고 이전 부분이 먼저 실행됩니다. 따라서이 수정자를 사용함으로써 함수는 메시지 발신자가 계약의 소유자인지 자동으로 확인한 다음 사실이라면 평소와 같이 계속됩니다. 그렇지 않으면 충돌합니다.
테스트
참고 : 견고성 테스트는 일반적으로 저수준 계약 기반 기능, 즉 스마트 계약의 내부 구조를 테스트하는 데 사용됩니다. JS 테스트는 종종 계약이 외부에서 올바르게 상호 작용할 수 있는지 테스트하는 데 사용됩니다. 이것이 최종 사용자가 할 일입니다.
- 선언이 참인지 거짓인지 확인합니다. 이 예에서는 숫자를 배치 된 계약의 초기 값과 비교합니다. "true"가 될 때마다 Assert.equals 섹션은 "True"를 나타내는 이벤트를 발행합니다.이 사건은 Truffle이 테스트 중에 듣는 것입니다.
이 시점에서, 우리는 또한 프로젝트 폴더의 루트에있는 package.json 파일을 업데이트 (또는 지금까지 필요한 종속성과 향후 필요한 것)를 업데이트해야합니다. >
참고 : 우리는 안전한 계산을위한 SAFEMATH 기능이기 때문에 서브를 빼기 위해 서브를 사용합니다.
이더 리움 dapps 및 화이트리스트 건물에 대한
블록 체인의 스마트 계약은 불변이기 때문에 배포 후 DAPP를 업데이트하는 것은 어려울 수 있습니다. 그러나 데이터 및 논리를 다른 계약으로 분리하거나 위임 된 통화를 사용하여 계약을 업그레이드하여 업그레이드 가능한 계약을 설계 할 수 있습니다. DAPP의 설계 단계에서 업그레이드 및 변경 계획은 매우 중요합니다. pragma solidity ^0.4.24;
import "../node_modules/openzeppelin-solidity/contracts/math/SafeMath.sol";
import "../node_modules/openzeppelin-solidity/contracts/ownership/Ownable.sol";
contract StoryDao is Ownable {
using SafeMath for uint256;
mapping(address => bool) whitelist;
uint256 public whitelistedNumber = 0;
mapping(address => bool) blacklist;
event Whitelisted(address addr, bool status);
event Blacklisted(address addr, bool status);
uint256 public daofee = 100; // 百分之几,即 100 为 1%
uint256 public whitelistfee = 10000000000000000; // 以 Wei 为单位,这是 0.01 以太币
event SubmissionCommissionChanged(uint256 newFee);
event WhitelistFeeChanged(uint256 newFee);
uint256 public durationDays = 21; // 故事章节持续时间(天)
uint256 public durationSubmissions = 1000; // 故事章节持续时间(条目)
function changedaofee(uint256 _fee) onlyOwner external {
require(_fee <= 1000); // 限制最大费用为 10%
daofee = _fee;
emit SubmissionCommissionChanged(_fee);
}
function changewhitelistfee(uint256 _fee) onlyOwner external {
require(_fee > 0); // 确保费用大于 0
whitelistfee = _fee;
emit WhitelistFeeChanged(_fee);
}
function changeDurationDays(uint256 _days) onlyOwner external {
require(_days >= 1);
durationDays = _days;
}
function changeDurationSubmissions(uint256 _subs) onlyOwner external {
require(_subs > 99);
durationSubmissions = _subs;
}
}
modifier onlyOwner() {
require(msg.sender == owner);
_;
}
export default async promise => {
try {
await promise;
} catch (error) {
const invalidOpcode = error.message.search('invalid opcode') >= 0;
const outOfGas = error.message.search('out of gas') >= 0;
const revert = error.message.search('revert') >= 0;
assert(
invalidOpcode || outOfGas || revert,
'Expected throw, got \'' + error + '\' instead',
);
return;
}
assert.fail('Expected throw not received');
};
pragma solidity ^0.4.24;
import "truffle/Assert.sol";
import "truffle/DeployedAddresses.sol";
import "../contracts/StoryDao.sol";
contract TestStoryDao {
function testDeploymentIsFine() public {
StoryDao sd = StoryDao(DeployedAddresses.StoryDao());
uint256 daofee = 100; // 百分之几,即 100 为 1%
uint256 whitelistfee = 10000000000000000; // 以 Wei 为单位,这是 0.01 以太币
uint256 durationDays = 21; // 故事章节持续时间(天)
uint256 durationSubmissions = 1000; // 故事章节持续时间(条目)
Assert.equal(sd.daofee(), daofee, "初始 DAO 费用应为 100");
Assert.equal(sd.whitelistfee(), whitelistfee, "初始白名单费用应为 0.01 以太币");
Assert.equal(sd.durationDays(), durationDays, "初始天数持续时间应设置为 3 周");
Assert.equal(sd.durationSubmissions(), durationSubmissions, "初始提交持续时间应设置为 1000 个条目");
}
}
테스트에 대한 자세한 내용은 스마트 계약 테스트를 다루기 위해 특별히 준비한이 튜토리얼을 참조하십시오. import expectThrow from './helpers/expectThrow';
const StoryDao = artifacts.require("StoryDao");
contract('StoryDao Test', async (accounts) => {
it("should make sure environment is OK by checking that the first 3 accounts have over 20 eth", async () =>{
assert.equal(web3.eth.getBalance(accounts[0]).toNumber() > 2e+19, true, "Account 0 has more than 20 eth");
assert.equal(web3.eth.getBalance(accounts[1]).toNumber() > 2e+19, true, "Account 1 has more than 20 eth");
assert.equal(web3.eth.getBalance(accounts[2]).toNumber() > 2e+19, true, "Account 2 has more than 20 eth");
});
it("should make the deployer the owner", async () => {
let instance = await StoryDao.deployed();
assert.equal(await instance.owner(), accounts[0]);
});
it("should let owner change fee and duration", async () => {
let instance = await StoryDao.deployed();
let newDaoFee = 50;
let newWhitelistFee = 1e+10; // 1 ether
let newDayDuration = 42;
let newSubsDuration = 1500;
instance.changedaofee(newDaoFee, {from: accounts[0]});
instance.changewhitelistfee(newWhitelistFee, {from: accounts[0]});
instance.changeDurationDays(newDayDuration, {from: accounts[0]});
instance.changeDurationSubmissions(newSubsDuration, {from: accounts[0]});
assert.equal(await instance.daofee(), newDaoFee);
assert.equal(await instance.whitelistfee(), newWhitelistFee);
assert.equal(await instance.durationDays(), newDayDuration);
assert.equal(await instance.durationSubmissions(), newSubsDuration);
});
it("should forbid non-owners from changing fee and duration", async () => {
let instance = await StoryDao.deployed();
let newDaoFee = 50;
let newWhitelistFee = 1e+10; // 1 ether
let newDayDuration = 42;
let newSubsDuration = 1500;
await expectThrow(instance.changedaofee(newDaoFee, {from: accounts[1]}));
await expectThrow(instance.changewhitelistfee(newWhitelistFee, {from: accounts[1]}));
await expectThrow(instance.changeDurationDays(newDayDuration, {from: accounts[1]}));
await expectThrow(instance.changeDurationSubmissions(newSubsDuration, {from: accounts[1]}));
});
it("should make sure the owner can only change fees and duration to valid values", async () =>{
let instance = await StoryDao.deployed();
let invalidDaoFee = 20000;
let invalidDayDuration = 0;
let invalidSubsDuration = 98;
await expectThrow(instance.changedaofee(invalidDaoFee, {from: accounts[0]}));
await expectThrow(instance.changeDurationDays(invalidDayDuration, {from: accounts[0]}));
await expectThrow(instance.changeDurationSubmissions(invalidSubsDuration, {from: accounts[0]}));
})
});
사용자가 스토리 구축에 참여할 수있는 화이트리스트 메커니즘을 구축합시다. 다음 함수 프레임 워크를 StoryDao.sol에 추가하십시오 :
pragma solidity ^0.4.24;
import "../node_modules/openzeppelin-solidity/contracts/math/SafeMath.sol";
import "../node_modules/openzeppelin-solidity/contracts/ownership/Ownable.sol";
contract StoryDao is Ownable {
using SafeMath for uint256;
mapping(address => bool) whitelist;
uint256 public whitelistedNumber = 0;
mapping(address => bool) blacklist;
event Whitelisted(address addr, bool status);
event Blacklisted(address addr, bool status);
uint256 public daofee = 100; // 百分之几,即 100 为 1%
uint256 public whitelistfee = 10000000000000000; // 以 Wei 为单位,这是 0.01 以太币
event SubmissionCommissionChanged(uint256 newFee);
event WhitelistFeeChanged(uint256 newFee);
uint256 public durationDays = 21; // 故事章节持续时间(天)
uint256 public durationSubmissions = 1000; // 故事章节持续时间(条目)
function changedaofee(uint256 _fee) onlyOwner external {
require(_fee <= 1000); // 限制最大费用为 10%
daofee = _fee;
emit SubmissionCommissionChanged(_fee);
}
function changewhitelistfee(uint256 _fee) onlyOwner external {
require(_fee > 0); // 确保费用大于 0
whitelistfee = _fee;
emit WhitelistFeeChanged(_fee);
}
function changeDurationDays(uint256 _days) onlyOwner external {
require(_days >= 1);
durationDays = _days;
}
function changeDurationSubmissions(uint256 _subs) onlyOwner external {
require(_subs > 99);
durationSubmissions = _subs;
}
}
modifier onlyOwner() {
require(msg.sender == owner);
_;
}
결론
DAO는 분산 된 자율 조직을 나타냅니다. 그것은 조직 구성원이 통제하고 중앙 정부의 영향을받지 않는 컴퓨터 프로그램으로 인코딩 된 규칙으로 표현되는 조직 유형입니다. DAO의 금융 거래 및 규칙은 블록 체인에 보관되어 DAPP가됩니다.
DAPP 개발은 몇 가지 과제에 직면 해 있습니다. 여기에는 이더 리움 네트워크의 확장 성 문제를 다루고, DAPP의 보안을 보장하고, 거래를위한 휘발성 가스 가격 관리 및 사용자 친화적 인 인터페이스 제공이 포함됩니다. 또한 빠르게 진화하는 블록 체인 기술 및 규정을 주시해야합니다.
위 내용은 이더 리움 DAPP 건축 : 화이트리스트 및 테스트 스토리 DAO의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

AI 분야에서 중국 여성 기술력의 부상 : 기술 분야에 대한 Deepseek 여성의 기여와의 명예의 협력에 대한 이야기는 점점 더 중요 해지고 있습니다. 중국 과학 기술부의 데이터에 따르면 여성 과학 기술 노동자의 수는 거대하며 AI 알고리즘 개발에서 독특한 사회적 가치 민감도를 보여줍니다. 이 기사는 명예 휴대폰에 중점을두고 DeepSeek Big Model에 처음 연결 한 여성 팀의 강점을 탐구하여 기술 발전을 촉진하고 기술 개발의 가치 좌표 시스템을 재구성 할 수있는 방법을 보여줍니다. 2024 년 2 월 8 일, Honor는 공식적으로 DeepSeek-R1 전혈 버전 Big Model을 출시하여 Android 캠프에서 최초의 제조업체가되어 DeepSeek에 연결하여 사용자의 열정적 인 응답을 불러 일으켰습니다. 이 성공 뒤에 여성 팀원은 제품 결정, 기술 혁신 및 사용자를 만들고 있습니다.

DeepSeek은 Zhihu에 대한 기술 기사를 발표하여 DeepSeek-V3/R1 추론 시스템을 자세히 소개하고 처음으로 주요 재무 데이터를 공개하여 업계의 관심을 끌었습니다. 이 기사는 시스템의 일일 비용 이익 마진이 545%로 높아 글로벌 AI Big Model 이익이 새로운 것으로 나타났습니다. DeepSeek의 저렴한 전략은 시장 경쟁에서 이점을 제공합니다. 모델 교육 비용은 유사한 제품의 1% -5%에 불과하며 V3 모델 교육 비용은 경쟁 업체의 비용보다 훨씬 낮으며 V3 모델 교육 비용은 5 억 5,760 만 달러에 불과합니다. 한편, R1의 API 가격은 Openaio3-Mini의 1/7에서 1/2에 불과합니다. 이 데이터는 DeepSeek 기술 경로의 상업적 타당성을 입증하고 AI 모델의 효율적인 수익성을 확립합니다.

웹 사이트 구성은 첫 번째 단계입니다 : SEO 및 백 링크의 중요성 웹 사이트 구축은 웹 사이트를 귀중한 마케팅 자산으로 전환하는 첫 번째 단계 일뿐입니다. 검색 엔진에서 웹 사이트의 가시성을 향상시키고 잠재 고객을 유치하려면 SEO 최적화를 수행해야합니다. 백 링크는 웹 사이트 순위를 향상시키는 열쇠이며 Google 및 기타 검색 엔진에 웹 사이트의 권한 및 신뢰성을 보여줍니다. 모든 백 링크가 유리한 것은 아닙니다. 유해한 링크를 식별하고 피하십시오. 모든 백 링크가 유익한 것은 아닙니다. 유해한 링크는 순위에 해를 끼칠 수 있습니다. 우수한 무료 백 링크 확인 도구는 웹 사이트 링크 소스를 모니터링하고 유해한 링크를 상기시킵니다. 또한 경쟁 업체의 링크 전략을 분석하고 배울 수도 있습니다. 무료 백 링크 점검 도구 : SEO 인텔리전스 책임자

MIDEA는 곧 Deepseek Big Model -Midea Fresh and Clean Air Machine T6을 갖춘 최초의 에어컨을 출시 할 예정입니다. 이 에어컨에는 고급 공기 지능형 주행 시스템이 장착되어있어 환경에 따라 온도, 습도 및 풍속과 같은 매개 변수를 지능적으로 조정할 수 있습니다. 더 중요한 것은 DeepSeek Big 모델을 통합하고 400,000 개 이상의 AI 음성 명령을 지원합니다. Midea의 움직임은 업계에서 격렬한 토론을 일으켰으며 특히 백색 제품과 대형 모델을 결합하는 중요성에 대해 우려하고 있습니다. 전통적인 에어컨의 간단한 온도 설정과 달리 MIDEA Fresh and Clean Air Machine T6은 가정 환경에 따라보다 복잡하고 모호한 지침을 이해하고 습도를 지능적으로 조정하여 사용자 경험을 크게 향상시킬 수 있습니다.

DeepSeek-R1은 Baidu Library 및 NetDisk에 권한을 부여합니다. 심도있는 사고와 행동의 완벽한 통합은 단 한 달 만에 많은 플랫폼에 빠르게 통합되었습니다. 대담한 전략적 레이아웃을 통해 Baidu는 DeepSeek을 타사 모델 파트너로 통합하여이를 생태계에 통합하여 "큰 모델 검색"생태 전략의 주요 진전을 나타냅니다. Baidu Search 및 Wenxin Intelligent Intelligent 플랫폼은 DeepSeek 및 Wenxin Big Model의 깊은 검색 기능에 처음으로 연결하여 사용자에게 무료 AI 검색 경험을 제공합니다. 동시에 "Baidu로 갈 때 알게 될 것입니다"라는 클래식 슬로건과 새로운 버전의 Baidu 앱은 Wenxin의 큰 모델과 DeepSeek의 기능을 통합하여 "AI Search"및 "Wide Network Information Refinement"를 시작합니다.

이 GO 기반 네트워크 취약점 스캐너는 잠재적 보안 약점을 효율적으로 식별합니다. 속도를 위해 Go의 동시성 기능을 활용하고 서비스 감지 및 취약성 일치를 포함합니다. 그 능력과 윤리를 탐색합시다

코드 생성을위한 AI 프롬프트 엔지니어링 : 개발자 안내서 코드 개발의 풍경은 상당한 변화를 위해 준비되어 있습니다. LLM (Large Language Model)과 신속한 엔지니어링을 마스터하는 것이 향후 몇 년 동안 개발자에게 중요 할 것입니다. th


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

드림위버 CS6
시각적 웹 개발 도구

Dreamweaver Mac版
시각적 웹 개발 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.
