当前位置: 首页 > news >正文

Web3.0:重新定义互联网的未来

在这里插入图片描述

💗wei_shuo的个人主页

💫wei_shuo的学习社区

🌐Hello World !


Web3.0:重新定义互联网的未来

Web3.0是指下一代互联网,也称为“分布式互联网”。相比于Web1.0和Web2.0,Web3.0具有更强的去中心化、智能化和安全性。目前,Web3.0正在快速发展,为互联网的未来带来了无限可能

Web3.0的核心特点是去中心化。在传统的互联网中,用户与服务提供商之间的关系是单向的,服务提供商掌握了用户的数据和信息。而在Web3.0中,用户可以通过去中心化的方式掌握自己的数据和信息,不再被服务提供商所控制

智能合约

智能合约是Web3.0的重要组成部分。智能合约是一种基于区块链技术的自动化合约,它可以自动执行并验证合约中的条款。智能合约的出现使得合约的执行更加高效、便捷和安全

下面是一个简单的智能合约实例:

pragma solidity ^0.4.0;contract HelloWorld {string public message;function HelloWorld(string initMessage) {message = initMessage;}function setMessage(string newMessage) {message = newMessage;}
}

这个智能合约可以让用户设置一个消息,并且其他用户可以查看这个消息。通过智能合约,用户可以在没有中间人的情况下进行交互

区块链技术

区块链是Web3.0的核心技术之一。它是一种去中心化的、不可篡改的分布式账本技术,可以记录交易、资产和权益等信息。区块链技术的安全性和透明度使其成为了Web3.0的重要基础;在区块链技术中,每个区块都包含了前一个区块的哈希值,这样就形成了一条不可篡改的链。通过这种方式,区块链技术可以有效地防止数据篡改和欺诈行为,从而保证了数据的安全性和可靠性

// 创建一个区块
class Block {constructor(index, timestamp, data, previousHash) {this.index = index;this.timestamp = timestamp;this.data = data;this.previousHash = previousHash;this.hash = this.calculateHash();}calculateHash() {return SHA256(this.index + this.timestamp + this.data + this.previousHash).toString();}
}// 创建一个区块链
class Blockchain {constructor() {this.chain = [this.createGenesisBlock()];}createGenesisBlock() {return new Block(0, new Date(), "Genesis Block", "0");}getLatestBlock() {return this.chain[this.chain.length - 1];}addBlock(newBlock) {newBlock.previousHash = this.getLatestBlock().hash;newBlock.hash = newBlock.calculateHash();this.chain.push(newBlock);}isValid() {for (let i = 1; i < this.chain.length; i++) {const currentBlock = this.chain[i];const previousBlock = this.chain[i - 1];if (currentBlock.hash !== currentBlock.calculateHash()) {return false;}if (currentBlock.previousHash !== previousBlock.hash) {return false;}}return true;}
}// 创建一个区块链实例
const blockchain = new Blockchain();// 添加新的区块
blockchain.addBlock(new Block(1, new Date(), { amount: 100 }));
blockchain.addBlock(new Block(2, new Date(), { amount: 200 }));// 验证区块链是否有效
console.log("Is blockchain valid? " + blockchain.isValid());

去中心化应用程序(DApps)

去中心化应用程序(DApps)是Web3.0的另一个重要技术。它们是基于区块链技术构建的应用程序,可以在没有中心化服务器的情况下运行。DApps具有更高的安全性和透明度,可以为用户提供更好的隐私保护和数据安全

// 创建一个简单的DApps
const DApps = {state: {count: 0},mutations: {increment(state) {state.count++;}},actions: {increment(context) {context.commit("increment");}}
};// 创建一个Vue实例
const app = new Vue({el: "#app",data: {count: 0},methods: {increment() {this.count++;}}
});// 将DApps与Vue实例进行绑定
Vuex.Store(DApps);
Vue.use(Vuex);// 在Vue实例中使用DApps
app.$store.dispatch("increment");

加密货币

加密货币是Web3.0的另一个重要技术。它们是基于区块链技术构建的数字货币,可以在全球范围内进行安全、快速、便捷的交易。加密货币使用密码学技术来保证交易的安全性和可靠性

// 创建一个简单的加密货币
class CryptoCurrency {constructor() {this.chain = [this.createGenesisBlock()];this.difficulty = 4;}createGenesisBlock() {return new Block(0, new Date(), "Genesis Block", "0");}getLatestBlock() {return this.chain[this.chain.length - 1];}addBlock(newBlock) {newBlock.previousHash = this.getLatestBlock().hash;newBlock.mineBlock(this.difficulty);this.chain.push(newBlock);}isValid() {for (let i = 1; i < this.chain.length; i++) {const currentBlock = this.chain[i];const previousBlock = this.chain[i - 1];if (currentBlock.hash !== currentBlock.calculateHash()) {return false;}if (currentBlock.previousHash !== previousBlock.hash) {return false;}}return true;}
}// 创建一个简单的加密货币交易
class Transaction {constructor(fromAddress, toAddress, amount) {this.fromAddress = fromAddress;this.toAddress = toAddress;this.amount = amount;}
}// 创建一个简单的区块
class Block {constructor(index, timestamp, data, previousHash) {this.index = index;this.timestamp = timestamp;this.data = data;this.previousHash = previousHash;this.nonce = 0;this.hash = this.calculateHash();}calculateHash() {return SHA256(this.index + this.timestamp + this.data + this.previousHash + this.nonce).toString();}mineBlock(difficulty) {while (this.hash.substring(0, difficulty) !== Array(difficulty + 1).join("0")) {this.nonce++;this.hash = this.calculateHash();}}
}// 创建一个加密货币实例
const cryptoCurrency = new CryptoCurrency();// 创建一个交易
const transaction = new Transaction("address1", "address2", 100);// 添加新的交易
cryptoCurrency.addBlock(new Block(1, new Date(), { transaction }));// 验证加密货币是否有效
console.log("Is cryptoCurrency valid? " + cryptoCurrency.isValid());

web3.0程序

Solidity编写智能合约并与以太坊区块链进行交互,实现了一个简单的投票系统

智能合约:

pragma solidity ^0.4.24;contract Voting {// 候选人结构体struct Candidate {string name;uint voteCount;}// 候选人数组Candidate[] public candidates;// 投票人地址到投票状态的映射mapping(address => bool) public voters;// 添加候选人function addCandidate(string _name) public {candidates.push(Candidate(_name, 0));}// 投票function vote(uint _candidateIndex) public {// 如果已经投过票,则抛出异常require(!voters[msg.sender]);// 如果候选人不存在,则抛出异常require(_candidateIndex < candidates.length);// 修改投票人状态为已投票voters[msg.sender] = true;// 候选人得票数加1candidates[_candidateIndex].voteCount++;}// 获取候选人数量function getCandidateCount() public view returns (uint) {return candidates.length;}// 获取候选人信息function getCandidate(uint _index) public view returns (string, uint) {return (candidates[_index].name, candidates[_index].voteCount);}
}

智能合约实现了以下功能:

  • 添加候选人
  • 投票
  • 获取候选人数量
  • 获取候选人信息

前端页面中,可以通过调用智能合约的方法来实现投票系统的功能

<!DOCTYPE html>
<html>
<head><title>Voting System</title><meta charset="utf-8"><script src="./web3.min.js"></script><script src="./abi.js"></script><script>var contractAddress = "0x1234567890abcdef1234567890abcdef12345678";var contractABI = abi; // 从abi.js中获取智能合约ABIvar contract;function init() {if (typeof web3 !== 'undefined') {web3 = new Web3(web3.currentProvider);} else {alert("Please install MetaMask.");}contract = new web3.eth.Contract(contractABI, contractAddress);}function addCandidate() {var name = document.getElementById("candidateName").value;contract.methods.addCandidate(name).send({from: web3.eth.defaultAccount}).then(function() {alert("Candidate added.");});}function vote() {var candidateIndex = document.getElementById("candidateIndex").value;contract.methods.vote(candidateIndex).send({from: web3.eth.defaultAccount}).then(function() {alert("Voted successfully.");});}function getCandidateCount() {contract.methods.getCandidateCount().call().then(function(count) {document.getElementById("candidateCount").innerHTML = count;});}function getCandidate() {var candidateIndex = document.getElementById("candidateIndex2").value;contract.methods.getCandidate(candidateIndex).call().then(function(result) {document.getElementById("candidateInfo").innerHTML = result[0] + ": " + result[1] + " votes";});}</script>
</head>
<body onload="init()"><h1>Voting System</h1><h2>Add Candidate</h2><input type="text" id="candidateName" placeholder="Candidate Name"><br><button onclick="addCandidate()">Add</button><h2>Vote</h2><input type="text" id="candidateIndex" placeholder="Candidate Index"><br><button onclick="vote()">Vote</button><h2>Get Candidate Count</h2><button onclick="getCandidateCount()">Get Count</button><div id="candidateCount"></div><h2>Get Candidate Info</h2><input type="text" id="candidateIndex2" placeholder="Candidate Index"><br><button onclick="getCandidate()">Get Info</button><div id="candidateInfo"></div>
</body>
</html>

前端页面通过调用智能合约的方法实现了以下功能:

  • 添加候选人
  • 投票
  • 获取候选人数量
  • 获取候选人信息

使用Web3.js与以太坊区块链交互时,需要先安装MetaMask插件并登录账户,否则无法使用

总结

Web3.0是下一代互联网的技术架构,它将互联网的功能扩展到了一个全新的层次。Web3.0的核心技术包括区块链、智能合约、去中心化应用程序(DApps)和加密货币等。这些技术为Web3.0提供了更大的安全性、透明度和可扩展性,使它成为下一代互联网的有力推动者


🌼 结语:创作不易,如果觉得博主的文章赏心悦目,还请——点赞👍收藏⭐️评论📝


在这里插入图片描述

相关文章:

Web3.0:重新定义互联网的未来

&#x1f497;wei_shuo的个人主页 &#x1f4ab;wei_shuo的学习社区 &#x1f310;Hello World &#xff01; Web3.0&#xff1a;重新定义互联网的未来 Web3.0是指下一代互联网&#xff0c;也称为“分布式互联网”。相比于Web1.0和Web2.0&#xff0c;Web3.0具有更强的去中心化、…...

2023年还能选择前端吗?

前言 在Github2022的 Octoverse年度报告上&#xff0c;稳居最多使用榜首的语言可以看到是JavaScript&#xff0c;作为前端中最为关键的一部分&#xff0c;这说明即使现在&#xff0c;前端这一块仍然是大量的人涌进来&#xff0c;依然是火热&#xff0c;但是&#xff0c;一门语…...

sheetJs / xlsx-js-style 纯前端实现导出 excel 表格及自定义单元格样式

文章目录 一、安装二、创建基础工作表三、设置单元格宽度/高度/隐藏单元格四、分配数字格式五、超链接六、单元格注释七、公式八、合并单元格九、自定义单元格样式十、项目地址 一、安装 xlsx 地址&#xff1a;https://www.npmjs.com/package/xlsxSheetJs 地址&#xff1a;htt…...

Redis 报错 RedisConnectionException: Unable to connect to x.x.x.x:6379

文章目录 Redis报错类型可能解决方案 Redis报错类型 org.springframework.data.redis.connection. spingboot调用redis出错 PoolException: Could not get a resource from the pool; 连接池异常:无法从池中获取资源; nested exception is io.lettuce.core. 嵌套异常 RedisConn…...

Stable Diffusion - 真人照片的高清修复 (StableSR + GFPGAN) 最佳实践

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/132032216 GFPGAN (Generative Facial Prior GAN) 算法&#xff0c;用于实现真实世界的盲脸恢复的算法&#xff0c;利用预训练的面部 GAN&#xf…...

细讲一个 TCP 连接能发多少个 HTTP 请求(一)

一道经典的面试题是从 URL 在浏览器被被输入到页面展现的过程中发生了什么&#xff0c;大多数回答都是说请求响应之后 DOM 怎么被构建&#xff0c;被绘制出来。但是你有没有想过&#xff0c;收到的 HTML 如果包含几十个图片标签&#xff0c;这些图片是以什么方式、什么顺序、建…...

了解 CVSS:通用漏洞评分系统的应用

漏洞威胁管理至关重要&#xff0c;因为网络犯罪是一种持续存在的全球风险。网络犯罪分子愿意利用软件中的任何漏洞来访问网络和设备。对使用该软件的软件开发人员和组织的影响可能很严重。用户必须处理攻击的结果&#xff0c;例如赎金或数据盗窃&#xff0c;并且还可能面临法律…...

Xilinx FPGA电源设计与注意事项

1 引言 随着半导体和芯片技术的飞速发展&#xff0c;现在的FPGA集成了越来越多的可配置逻辑资源、各种各样的外部总线接口以及丰富的内部RAM资源&#xff0c;使其在国防、医疗、消费电子等领域得到了越来越广泛的应用。当采用FPGA进行设计电路时&#xff0c;大多数FPGA对上电的…...

前端:地图篇(一)

1、前言 在很多的出行程序中&#xff0c;都会使用到地图这一个功能&#xff0c;在实际的开发中我们也不会去开发一个自己的地图模型。如果自己开发一个地图模型&#xff0c;那么需要投入的成本、人力都是非常巨大的。所以我们很多网站和APP中使用的都是第三方的接口和JS&#…...

刷题笔记 day6

力扣 57 和为s的两个整数 class Solution { public:vector<int> twoSum(vector<int>& nums, int target) {vector<int> v;int i 0 , j nums.size()-1;while(i < j){if(nums[i] nums[j] > target){--j;}else if(nums[i] nums[j] < target){i…...

Drools用户手册翻译——第四章 Drools规则引擎(十一)复杂事件处理(CEP)的属性更改设置和监听器

甩锅声明&#xff1a;本人英语一般&#xff0c;翻译只是为了做个笔记&#xff0c;所以有翻译错误的地方&#xff0c;错就错了&#xff0c;如果你想给我纠正&#xff0c;就给我留言&#xff0c;我会改过来&#xff0c;如果懒得理我&#xff0c;就直接划过即可。 事实类型的属性…...

[数据分析与可视化] Python绘制数据地图4-MovingPandas入门指北

MovingPandas是一个基于Python和GeoPandas的开源地理时空数据处理库&#xff0c;用于处理移动物体的轨迹数据。它提供了一组强大的工具&#xff0c;可以轻松地加载、分析和可视化移动物体的轨迹。通过使用MovingPandas&#xff0c;用户可以轻松地处理和分析移动对象数据&#x…...

基于SpringBoot+Vue的MOBA类游戏攻略分享平台设计与实现(源码+LW+部署文档等)

博主介绍&#xff1a; 大家好&#xff0c;我是一名在Java圈混迹十余年的程序员&#xff0c;精通Java编程语言&#xff0c;同时也熟练掌握微信小程序、Python和Android等技术&#xff0c;能够为大家提供全方位的技术支持和交流。 我擅长在JavaWeb、SSH、SSM、SpringBoot等框架…...

Linux sed 命令详解

Linux sed&#xff08;Stream Editor&#xff09;是一种强大的文本处理工具&#xff0c;它在命令行中执行对文本进行搜索、替换和编辑等操作。sed的设计理念是按行处理文本&#xff0c;可以将输入文本逐行读取并应用指定的操作&#xff0c;然后输出结果。 sed命令有多种选项和…...

算法通关村——如何使用中序和后序来恢复一棵二叉树

通过序列构造二叉树 给出以下三个二叉树遍历的序列&#xff1a; (1) 前序: 1 2 3 4 5 6 8 7 9 10 11 12 13 15 14 (2) 中序: 3 4 8 6 7 5 2 1 10 9 11 15 13 14 12 (3) 后序: 8 7 6 5 4 3 2 10 15 14 13 12 11 9 1 前中序复原二叉树 所需序列 (1) 前序: 1 2 3 4 5 6 8 7 9 10 …...

TypeScript的基本类型

typescript的定义 以JavaScript为基础构建的语言是js的超集可以在任何支持js的平台执行ts 拓展了js并增加了类型Ts不能被js解析器直接执行。 TS> 编译为js 执行的还是js. js 不易于维护&#xff0c;而ts易于维护。 可提高项目的可维护性。 类似less、sass 完善的语法写 样…...

Docker实战-如何去访问Docker仓库?

导语   仓库在之前的分享中我们介绍过,它主要的作用就是用来存放镜像文件,又可以分为是公共的仓库和私有仓库。有点类似于Maven的中央仓库和公司内部私服。 下面我们就来介绍一下在Docker中如何去访问各种仓库。 Docker Hub 公共镜像仓库 Docker Hub 是Docker官方提供的最…...

【力扣】722. 删除注释

以下为力扣官方题解&#xff0c;及本人代码 722. 删除注释 题目题意示例 1示例 2提示 官方题解模拟思路与算法复杂度 本人代码Java提交结果&#xff1a;通过 题目 题意 给一个 C C C 程序&#xff0c;删除程序中的注释。这个程序 s o u r c e source source 是一个数组&a…...

篇二:工厂方法模式:灵活创建对象

篇二&#xff1a;“工厂方法模式&#xff1a;灵活创建对象” 开始本篇文章之前先推荐一个好用的学习工具&#xff0c;AIRIght&#xff0c;借助于AI助手工具&#xff0c;学习事半功倍。欢迎访问&#xff1a;http://airight.fun/。 另外有2本不错的关于设计模式的资料&#xff…...

Python(六十二)字典元素的增、删、改操作

❤️ 专栏简介&#xff1a;本专栏记录了我个人从零开始学习Python编程的过程。在这个专栏中&#xff0c;我将分享我在学习Python的过程中的学习笔记、学习路线以及各个知识点。 ☀️ 专栏适用人群 &#xff1a;本专栏适用于希望学习Python编程的初学者和有一定编程基础的人。无…...

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站&#xff0c;会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后&#xff0c;网站没有变化的情况。 不熟悉siteground主机的新手&#xff0c;遇到这个问题&#xff0c;就很抓狂&#xff0c;明明是哪都没操作错误&#x…...

HTML 语义化

目录 HTML 语义化HTML5 新特性HTML 语义化的好处语义化标签的使用场景最佳实践 HTML 语义化 HTML5 新特性 标准答案&#xff1a; 语义化标签&#xff1a; <header>&#xff1a;页头<nav>&#xff1a;导航<main>&#xff1a;主要内容<article>&#x…...

ssc377d修改flash分区大小

1、flash的分区默认分配16M、 / # df -h Filesystem Size Used Available Use% Mounted on /dev/root 1.9M 1.9M 0 100% / /dev/mtdblock4 3.0M...

AtCoder 第409​场初级竞赛 A~E题解

A Conflict 【题目链接】 原题链接&#xff1a;A - Conflict 【考点】 枚举 【题目大意】 找到是否有两人都想要的物品。 【解析】 遍历两端字符串&#xff0c;只有在同时为 o 时输出 Yes 并结束程序&#xff0c;否则输出 No。 【难度】 GESP三级 【代码参考】 #i…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)

设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile&#xff0c;新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...

uniapp中使用aixos 报错

问题&#xff1a; 在uniapp中使用aixos&#xff0c;运行后报如下错误&#xff1a; AxiosError: There is no suitable adapter to dispatch the request since : - adapter xhr is not supported by the environment - adapter http is not available in the build 解决方案&…...

ios苹果系统,js 滑动屏幕、锚定无效

现象&#xff1a;window.addEventListener监听touch无效&#xff0c;划不动屏幕&#xff0c;但是代码逻辑都有执行到。 scrollIntoView也无效。 原因&#xff1a;这是因为 iOS 的触摸事件处理机制和 touch-action: none 的设置有关。ios有太多得交互动作&#xff0c;从而会影响…...

C++八股 —— 单例模式

文章目录 1. 基本概念2. 设计要点3. 实现方式4. 详解懒汉模式 1. 基本概念 线程安全&#xff08;Thread Safety&#xff09; 线程安全是指在多线程环境下&#xff0c;某个函数、类或代码片段能够被多个线程同时调用时&#xff0c;仍能保证数据的一致性和逻辑的正确性&#xf…...

如何理解 IP 数据报中的 TTL?

目录 前言理解 前言 面试灵魂一问&#xff1a;说说对 IP 数据报中 TTL 的理解&#xff1f;我们都知道&#xff0c;IP 数据报由首部和数据两部分组成&#xff0c;首部又分为两部分&#xff1a;固定部分和可变部分&#xff0c;共占 20 字节&#xff0c;而即将讨论的 TTL 就位于首…...

【Oracle】分区表

个人主页&#xff1a;Guiat 归属专栏&#xff1a;Oracle 文章目录 1. 分区表基础概述1.1 分区表的概念与优势1.2 分区类型概览1.3 分区表的工作原理 2. 范围分区 (RANGE Partitioning)2.1 基础范围分区2.1.1 按日期范围分区2.1.2 按数值范围分区 2.2 间隔分区 (INTERVAL Partit…...