主頁 > 區塊鏈 > CGB2005-京淘16

CGB2005-京淘16

2020-09-17 04:56:23 區塊鏈

1.關于跨域的說明

1.1 跨域訪問測驗

測驗1: 同服務器測驗

說明:
1.瀏覽器的網址資訊: http://manage.jt.com/test.html
2.ajax請求的地址資訊: http://manage.jt.com/test.json

發現: 請求協議名稱://域名:埠號都相同時,請求可以正常進行.

測驗2: 不同的服務器測驗

說明:;
1.瀏覽器的網址資訊: http://www.jt.com/test.html
2.ajax請求的地址資訊: http://manage.jt.com/test.json
結論: 域名地址不相同時請求不能正常獲取回應的結果.

1.2 同源策略介紹

說明:
瀏覽器在決議ajax時,如果發現請求的協議名稱://請求的域名:請求的埠號與網址的地址都相同的時滿足同源策略的規定,瀏覽器可以正確的決議回傳值.該訪問稱之為同域訪問.該策略叫做同源策略.
但是如果違反了同源策略中的任意一條,則叫做跨域訪問.瀏覽器出于安全性的考慮.不予決議回傳值(請求正常的被處理,但是接收不到回傳值).

概括: 瀏覽器決議ajax時,由于請求違反了同源策略則稱之為跨域請求.
在這里插入圖片描述
在這里插入圖片描述
例子: http://localhost:8091/xxx.html
http://manage.jt.com/xx.html 不可以通訊

1.3 JSONP實作跨域

1.3.1 JSONP實作跨域的原理(有難度)

1.javaScript中的src屬性不受同源策略的約束.可以獲取遠程服務器資料.

<!--該json一直保存到瀏覽器中等待呼叫,但是沒有函式名稱無法呼叫  -->
	<script type="text/javascript" src="http://manage.jt.com/test.json"></script>

2.自定義回呼函式 名稱任意

/*定義回呼函式  */
		function hello(data){
			alert(data.name);
		}

3.將回傳值結果進行特殊的格式封裝 callback(JSON);

hello({"id":"1","name":"tomcat貓"})

1.3.2 JSONP優化策略

1.利用script中的src屬性發起請求不方便.不便于程式使用. 能否封裝為ajax呼叫方式
2.在請求路徑中拼接一個引數一般的key都是約定俗稱的 http:xxx/xx?callback=“自定義函式名稱”
3.動態的獲取callback的引數名稱之后進行特殊的格式封裝 callback(JSON);

1.3.3 JSONP概念

JSONP(JSON with Padding)是JSON的一種“使用模式”,可用于解決主流瀏覽器的跨域資料訪問的問題,由于同源策略,一般來說位于 server1.example.com 的網頁無法與不是 server1.example.com的服務器溝通,而 HTML 的

1.3.3 JSONP的Ajax呼叫

<script type="text/javascript">
	$(function(){
		alert("測驗訪問開始!!!!!")
		$.ajax({
			url:"http://manage.jt.com/web/testJSONP",
			type:"get",				//jsonp只能支持get請求 src只能是get請求
			dataType:"jsonp",       //dataType表示回傳值型別
			//jsonp: "callback",    //指定引數名稱
			//jsonpCallback: "hello",  //指定回呼函式名稱
			success:function (data){   //data經過jQuery封裝回傳就是json串
				alert(data.itemId);
				alert(data.itemDesc);
			}
		});	
	})
</script>

1.3.4 編輯后臺Controller回傳資料

package com.jt.web.controller;

import com.jt.pojo.ItemDesc;
import com.jt.util.ObjectMapperUtil;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class JSONPController {

    /**
     * 測驗跨域訪問是否成功
     * url地址: http://manage.jt.com/web/testJSONP?callback=jQuery111106536880527642785_1600138715329&_=1600138715330
     * 回傳值的應該是經過特殊格式封裝的資料.  callback(JSON)
     */
    @RequestMapping("/web/testJSONP")
    public String  jsonp(String callback){
        ItemDesc itemDesc = new ItemDesc();
        itemDesc.setItemId(100L).setItemDesc("跨域測驗成功!!!!");
        String json = ObjectMapperUtil.toJSON(itemDesc);
        return callback+"("+json+")";
    }
}

1.3.5 編輯JSONPObject物件

 /**
     * 測驗跨域訪問是否成功
     * url地址: http://manage.jt.com/web/testJSONP?callback=jQuery111106536880527642785_1600138715329&_=1600138715330
     * 回傳值的應該是經過特殊格式封裝的資料.  callback(JSON)
     * JSONPObject引數說明:
     *  1.function 回呼函式名稱
     *  2.回傳的物件之后可以被轉化為JSON
     */
    @RequestMapping("/web/testJSONP")
    public JSONPObject jsonp(String callback){
        ItemDesc itemDesc = new ItemDesc();
        itemDesc.setItemId(100L).setItemDesc("API測驗!!!");
        return new JSONPObject(callback, itemDesc);
    }

1.3.6 關于ajax請求時間毫秒數的說明

說明:由于瀏覽器內部有快取機制,所以如果遇到了一個相同的請求地址,瀏覽器可能會使用之間的結果.(使用快取),但是有些資料必須要求瀏覽器重資料庫中動態獲取資料,為了避免瀏覽器快取一般在url最后添加亂數或者時間毫秒數區分url請求.實作該功能.

在這里插入圖片描述

1.4 CORS跨域方式

1.4.1 跨域訪問測驗

<script type="text/javascript">
	/*$(){}結構必然是jQuery函式類別庫匯入后才能正確執行*/
	$(function(){
		alert("我執行了AJAX");
		//利用jQuery發起AJAX請求
		$.get("http://manage.jt.com/test.json",function(data){
			alert(data.name);
		})
	})
</script>

在這里插入圖片描述

1.4.2 CORS跨域說明

說明:當下的主流的瀏覽器默認支持cors跨域的形式,但是需要服務器添加回應的資訊.否則瀏覽器不支持資料的獲取.
在這里插入圖片描述

1.4.3 編輯CORS配置類

說明:在jt-common中添加CORS的配置類

package com.jt.config;

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@Configuration
public class CORSConfig implements WebMvcConfigurer {

    /**
     * 實作跨域的方式
     * 需要配置服務端程式
     * 方法說明:
     *      1.addMapping(/**) 允許什么樣的請求可以跨域  所有的請求
     *      2.allowedOrigins("*")可以允許任意的域名
     *      3.allowCredentials(true) 跨域時是否允許攜帶cookie等引數
     */
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
                .allowedOrigins("*")
                .allowCredentials(true);
    }
}

1.4.4 跨域測驗

在這里插入圖片描述
在這里插入圖片描述

2. 京淘單點登錄系統

2.1 通用頁面跳轉

2.1.1 業務分析

1.注冊的url地址

http://www.jt.com/user/register.html

2.登錄的url地址

http://www.jt.com/user/login.html

2.1.2 編輯UserController

package com.jt.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller //由于設計到頁面跳轉功能.
@RequestMapping("/user")
public class UserController {

    /**
     * 通用頁面跳轉實作
     * 1.http://www.jt.com/user/login.html       login.jsp頁面
     * 2.http://www.jt.com/user/register.html    register.jsp頁面
     */
    @RequestMapping("/{moduleName}")
    public String module(@PathVariable String moduleName){

        return moduleName;
    }

}

2.1.3 頁面效果展現

在這里插入圖片描述

2.2 創建JT-SSO專案

2.2.1 JT-SSO專案說明

作用:主要為jt-web的服務器提供用戶的資料的支持,但凡涉及到user的CRUD操作都應該由該系統完成.
打包方式: jar包程式
注意事項: 繼承jt/ 依賴jt-common 添加插件.
埠號: 8093
在這里插入圖片描述

2.2.2 創建專案

在這里插入圖片描述

2.2.3 編輯pom.xml組態檔

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <artifactId>jt-sso</artifactId>

    <parent>
        <artifactId>jt</artifactId>
        <groupId>org.example</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>

    <!--添加依賴項-->
    <dependencies>
        <dependency>
            <groupId>org.example</groupId>
            <artifactId>jt-common</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
    </dependencies>

    <!--添加插件-->
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

2.2.4 編輯User的POJO物件

@TableName("tb_user")
@Data
@Accessors(chain = true)
public class User extends BasePojo{

    @TableId(type = IdType.AUTO)    //主鍵自增
    private Long id;
    private String username;    //用戶名
    private String password;    //密碼
    private String phone;       //電話
    private String email;       //郵箱 由于email暫時沒有使用電話代替

}

2.2.4 實作JT-SSO代碼結構

在這里插入圖片描述

2.2.5 編輯Nginx實作反向代理

注意hosts檔案的配置. 修改nginx之后重啟服務器.

#搭建jt-sso服務器
	server {
		listen 80;
		server_name sso.jt.com;

		location / {
			proxy_pass http://localhost:8093;
		}
	}

2.3 用戶資料校驗的分析

2.3.1 頁面url分析

在這里插入圖片描述

2.3.2 檢索頁面JS

在這里插入圖片描述

2.3.3 頁面JS分析

 $.ajax({
            	url : "http://sso.jt.com/user/check/"+escape(pin)+"/1?r=" + Math.random(),
            	dataType : "jsonp",
            	success : function(data) {      //狀態資訊:200 成功   狀態資訊:201 失敗
                    checkpin = data.data?"1":"0";
                    if(data.status == 200){
                        if (!data.data) {
                            validateSettings.succeed.run(option);
                            namestate = true;
                        }else {
                            validateSettings.error.run(option, "該用戶名已占用!");
                            namestate = false;
                        }
                    }else{
                        //標識后臺服務器運行例外
                        validateSettings.error.run(option, "服務器正忙,請稍后!!!(我后臺報錯了我也不知道啥錯!!!)");
                        namestate = false;
                    }
                }
            });

2.2.6 單點登錄業務介面

在這里插入圖片描述

2.2.7 編輯jt-sso的UserController

package com.jt.controller;

import com.fasterxml.jackson.databind.util.JSONPObject;
import com.jt.pojo.User;
import com.jt.service.UserService;
import com.jt.vo.SysResult;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

@RestController
@RequestMapping("/user")
public class UserController {

    @Autowired
    private UserService userService;

    @RequestMapping("/findAll")
    public List<User> findAll(){

        return userService.findAll();
    }

    /**
     * JSONP的跨域請求  特殊的格式封裝.....
     * 需求分析:校驗用戶的資料是否可用.
     * url: http://sso.jt.com/user/check/{param}/{type}
     * 引數: param/type
     * 回傳值結果: SysResult物件
     */
    @RequestMapping("/check/{param}/{type}")
    public JSONPObject chcekUser(@PathVariable String param,
                                 @PathVariable Integer type,
                                 String callback){
        //根據資訊查詢資料庫獲取回應記錄
        Boolean flag = userService.checkUser(param,type);
        return new JSONPObject(callback, SysResult.success(flag));
    }
}

2.2.8 編輯jt-sso的UserService

package com.jt.service;

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.jt.mapper.UserMapper;
import com.jt.pojo.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

@Service
public class UserServiceImpl implements  UserService{

    private static Map<Integer,String> paramMap = new HashMap<>();
    static {
        paramMap.put(1, "username");
        paramMap.put(2, "phone");
        paramMap.put(3, "email");
    }


    @Autowired
    private UserMapper userMapper;


    @Override
    public List<User> findAll() {

        return userMapper.selectList(null);
    }

    /**
     * 校驗資料是否存在即可. 查詢總記錄數即可.
     * @param param   需要校驗的資料
     * @param type    校驗的型別 1username 2phone 3 email 6789910
     * @return
     */
    @Override
    public Boolean checkUser(String param, Integer type) {
        String column = paramMap.get(type);
        QueryWrapper<User> queryWrapper = new QueryWrapper<>();
        queryWrapper.eq(column, param);
        //boolean flag = userMapper.selectCount(queryWrapper)>0?true:false;
        return userMapper.selectCount(queryWrapper)>0;
    }
}

2.2.9 頁面效果展現

在這里插入圖片描述

2.2.10 修改全域例外處理機制

package com.jt.aop;

import com.fasterxml.jackson.databind.util.JSONPObject;
import com.jt.vo.SysResult;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.RestControllerAdvice;

import javax.servlet.http.HttpServletRequest;

@RestControllerAdvice   //作用: 標識我是一個通知方法,并且只攔截Controll層的例外.并且回傳JSON.
public class SysResultException {

    //需要定義一個全域的方法 回傳指定的報錯資訊.
    //ExceptionHandler 配置例外的型別,當遇到了某種例外時在執行該方法.
    //JSONP的例外處理應該是 callback({status:201,msg:"",data:""})
    //利用Request物件動態獲取callback引數.之后動態封裝回傳值
    @ExceptionHandler(RuntimeException.class)
    public Object exception(Exception e, HttpServletRequest request){
        e.printStackTrace();
        String callback = request.getParameter("callback");
        if(!StringUtils.isEmpty(callback)){ //jsonp請求
            return new JSONPObject(callback, SysResult.fail());
        }
           //日志記錄/控制臺輸出. 讓程式員知道哪里報錯!!!
        return SysResult.fail();
    }
}

3.微服務框架介紹

3.1遠程呼叫的說明

瀏覽器決議ajax發起跨域請求.程式雖然可以正確的呼叫,但是瀏覽器可以監控用戶的所有的引數及回傳值.在一些特定的條件下該操作不安全.
一般使用跨域的請求都是用來獲取其他服務器的資料(查詢操作),如果遇到了POST需要提交的引數應該使用更加安全的請求方式實作.

3.2 HttpClient介紹

HTTP 協議可能是現在 Internet 上使用得最多、最重要的協議了,越來越多的 Java 應用程式需要直接通過 HTTP 協議來訪問網路資源,雖然在 JDK 的 java net包中已經提供了訪問 HTTP 協議的基本功能,但是對于大部分應用程式來說,JDK 庫本身提供的功能還不夠豐富和靈活,HttpClient 是 Apache Jakarta Common 下的子專案,用來提供高效的、最新的、功能豐富的支持 HTTP 協議的客戶端編程工具包,并且它支持 HTTP 協議最新的版本和建議,HttpClient 已經應用在很多的專案中,比如 Apache Jakarta 上很著名的另外兩個開源專案 Cactus 和 HTMLUnit 都使用了 HttpClient,現在HttpClient最新版本為 HttpClient 4.5 .6(2015-09-11)
在這里插入圖片描述

3.3 HttpClient入門案例

3.3.1 匯入jar包

<!--添加httpClient jar包 -->
        <dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpclient</artifactId>
        </dependency>

3.3.2 入門案例

package com.jt.test;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import org.junit.jupiter.api.Test;

import java.io.IOException;

public class TestHttpClient {

    /**
     * 步驟:
     *  1.實體化httpClient工具API
     *  2.定義請求url地址  任意網路地址....
     *  3.定義請求的型別  get/post/put/delete
     *  4.發起請求,獲取回應的結果
     *  5.判斷回應的狀態碼資訊.  200 404 500 406 400....
     *  6.動態決議回傳值執行后續操作.
     */
    @Test
    public void test01(){
        HttpClient httpClient = HttpClients.createDefault();
        String url = "https://www.baidu.com/";
        HttpGet get = new HttpGet(url);
        try {
            HttpResponse httpResponse = httpClient.execute(get);
            //判斷狀態碼是否正確
            int statusCode = httpResponse.getStatusLine().getStatusCode();
            if(statusCode == 200){
                //表示請求正確
                HttpEntity httpEntity = httpResponse.getEntity(); //獲取服務器的全部回應資訊(json/html/xml/xxxx)
                String result = EntityUtils.toString(httpEntity,"UTF-8");
                //獲取之后可以執行業務處理......
                System.out.println(result);
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

轉載請註明出處,本文鏈接:https://www.uj5u.com/qukuanlian/62623.html

標籤:區塊鏈

上一篇:漢諾塔問題(遞回寫法)

下一篇:英偉達斥資 400 億美元收購 Arm,欲向 Arm 員工發 15 億美元股票

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • JAVA使用 web3j 進行token轉賬

    最近新學習了下區塊鏈這方面的知識,所學不多,給大家分享下。 # 1. 關于web3j web3j是一個高度模塊化,反應性,型別安全的Java和Android庫,用于與智能合約配合并與以太坊網路上的客戶端(節點)集成。 # 2. 準備作業 jdk版本1.8 引入maven <dependency> < ......

    uj5u.com 2020-09-10 03:03:06 more
  • 以太坊智能合約開發框架Truffle

    前言 部署智能合約有多種方式,命令列的瀏覽器的渠道都有,但往往跟我們程式員的風格不太相符,因為我們習慣了在IDE里寫了代碼然后打包運行看效果。 雖然現在IDE中已經存在了Solidity插件,可以撰寫智能合約,但是部署智能合約卻要另走他路,沒辦法進行一個快捷的部署與測驗。 如果團隊管理的區塊節點多、 ......

    uj5u.com 2020-09-10 03:03:12 more
  • 谷歌二次驗證碼成為區塊鏈專用安全碼,你怎么看?

    前言 谷歌身份驗證器,前些年大家都比較陌生,但隨著國內互聯網安全的加強,它越來越多地出現在大家的視野中。 比較廣泛接觸的人群是國際3A游戲愛好者,游戲盜號現象嚴重+國外賬號安全應用廣泛,這類游戲一般都會要求用戶系結名為“兩步驗證”、“雙重驗證”等,平臺一般都推薦用谷歌身份驗證器。 后來區塊鏈業務風靡 ......

    uj5u.com 2020-09-10 03:03:17 more
  • 密碼學DAY1

    目錄 ##1.1 密碼學基本概念 密碼在我們的生活中有著重要的作用,那么密碼究竟來自何方,為何會產生呢? 密碼學是網路安全、資訊安全、區塊鏈等產品的基礎,常見的非對稱加密、對稱加密、散列函式等,都屬于密碼學范疇。 密碼學有數千年的歷史,從最開始的替換法到如今的非對稱加密演算法,經歷了古典密碼學,近代密 ......

    uj5u.com 2020-09-10 03:03:50 more
  • 密碼學DAY1_02

    目錄 ##1.1 ASCII編碼 ASCII(American Standard Code for Information Interchange,美國資訊交換標準代碼)是基于拉丁字母的一套電腦編碼系統,主要用于顯示現代英語和其他西歐語言。它是現今最通用的單位元組編碼系統,并等同于國際標準ISO/IE ......

    uj5u.com 2020-09-10 03:04:50 more
  • 密碼學DAY2

    ##1.1 加密模式 加密模式:https://docs.oracle.com/javase/8/docs/api/javax/crypto/Cipher.html ECB ECB : Electronic codebook, 電子密碼本. 需要加密的訊息按照塊密碼的塊大小被分為數個塊,并對每個塊進 ......

    uj5u.com 2020-09-10 03:05:42 more
  • NTP時鐘服務器的特點(京準電子)

    NTP時鐘服務器的特點(京準電子) NTP時鐘服務器的特點(京準電子) 京準電子官V——ahjzsz 首先對時間同步進行了背景介紹,然后討論了不同的時間同步網路技術,最后指出了建立全球或區域時間同步網存在的問題。 一、概 述 在通信領域,“同步”概念是指頻率的同步,即網路各個節點的時鐘頻率和相位同步 ......

    uj5u.com 2020-09-10 03:05:47 more
  • 標準化考場時鐘同步系統推進智能化校園建設

    標準化考場時鐘同步系統推進智能化校園建設 標準化考場時鐘同步系統推進智能化校園建設 安徽京準電子科技官微——ahjzsz 一、背景概述隨著教育事業的快速發展,學校建設如雨后春筍,隨之而來的學校教育、管理、安全方面的問題成了學校管理人員面臨的最大的挑戰,這些問題同時也是學生家長所擔心的。為了讓學生有更 ......

    uj5u.com 2020-09-10 03:05:51 more
  • 位元幣入門

    引言 位元幣基本結構 位元幣基礎知識 1)哈希演算法 2)非對稱加密技術 3)數字簽名 4)MerkleTree 5)哪有位元幣,有的是UTXO 6)位元幣挖礦與共識 7)區塊驗證(共識) 總結 引言 上一篇我們已經知道了什么是區塊鏈,此篇說一下區塊鏈的第一個應用——位元幣。其實先有位元幣,后有的區塊 ......

    uj5u.com 2020-09-10 03:06:15 more
  • 北斗對時服務器(北斗對時設備)電力系統應用

    北斗對時服務器(北斗對時設備)電力系統應用 北斗對時服務器(北斗對時設備)電力系統應用 京準電子科技官微(ahjzsz) 中國北斗衛星導航系統(英文名稱:BeiDou Navigation Satellite System,簡稱BDS),因為是目前世界范圍內唯一可以大面積提供免費定位服務的系統,所以 ......

    uj5u.com 2020-09-10 03:06:20 more
最新发布
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:46:47 more
  • Hyperledger Fabric 使用 CouchDB 和復雜智能合約開發

    在上個實驗中,我們已經實作了簡單智能合約實作及客戶端開發,但該實驗中智能合約只有基礎的增刪改查功能,且其中的資料管理功能與傳統 MySQL 比相差甚遠。本文將在前面實驗的基礎上,將 Hyperledger Fabric 的默認資料庫支持 LevelDB 改為 CouchDB 模式,以實作更復雜的資料... ......

    uj5u.com 2023-04-16 07:28:31 more
  • .NET Core 波場鏈離線簽名、廣播交易(發送 TRX和USDT)筆記

    Get Started NuGet You can run the following command to install the Tron.Wallet.Net in your project. PM> Install-Package Tron.Wallet.Net 配置 public reco ......

    uj5u.com 2023-04-14 08:08:00 more
  • DKP 黑客分析——不正確的代幣對比率計算

    概述: 2023 年 2 月 8 日,針對 DKP 協議的閃電貸攻擊導致該協議的用戶損失了 8 萬美元,因為 execute() 函式取決于 USDT-DKP 對中兩種代幣的余額比率。 智能合約黑客概述: 攻擊者的交易:0x0c850f,0x2d31 攻擊者地址:0xF38 利用合同:0xf34ad ......

    uj5u.com 2023-04-07 07:46:09 more
  • Defi開發簡介

    Defi開發簡介 介紹 Defi是去中心化金融的縮寫, 是一項旨在利用區塊鏈技術和智能合約創建更加開放,可訪問和透明的金融體系的運動. 這與傳統金融形成鮮明對比,傳統金融通常由少數大型銀行和金融機構控制 在Defi的世界里,用戶可以直接從他們的電腦或移動設備上訪問廣泛的金融服務,而不需要像銀行或者信 ......

    uj5u.com 2023-04-05 08:01:34 more
  • solidity簡單的ERC20代幣實作

    // SPDX-License-Identifier: GPL-3.0 pragma solidity >=0.7.0 <0.9.0; import "hardhat/console.sol"; //ERC20 同質化代幣,每個代幣的本質或性質都是相同 //ETH 是原生代幣,它不是ERC20代幣, ......

    uj5u.com 2023-03-21 07:56:29 more
  • solidity 參考型別修飾符memory、calldata與storage 常量修飾符C

    在solidity語言中 參考型別修飾符(參考型別為存盤空間不固定的數值型別) memory、calldata與storage,它們只能修飾參考型別變數,比如字串、陣列、位元組等... memory 適用于方法傳參、返參或在方法體內使用,使用完就會清除掉,釋放記憶體 calldata 僅適用于方法傳參 ......

    uj5u.com 2023-03-08 07:57:54 more
  • solidity注解標簽

    在solidity語言中 注釋符為// 注解符為/* 內容*/ 或者 是 ///內容 注解中含有這幾個標簽給予我們使用 @title 一個應該描述合約/介面的標題 contract, library, interface @author 作者的名字 contract, library, interf ......

    uj5u.com 2023-03-08 07:57:49 more
  • 評價指標:相似度、GAS消耗

    【代碼注釋自動生成方法綜述】 這些評測指標主要來自機器翻譯和文本總結等研究領域,可以評估候選文本(即基于代碼注釋自動方法而生成)和參考文本(即基于手工方式而生成)的相似度. BLEU指標^[^?88^^?^]^:其全稱是bilingual evaluation understudy.該指標是最早用于 ......

    uj5u.com 2023-02-23 07:27:39 more
  • 基于NOSTR協議的“公有制”版本的Twitter,去中心化社交軟體Damus

    最近,一個幽靈,Web3的幽靈,在網路游蕩,它叫Damus,這玩意詮釋了什么叫做病毒式營銷,滑稽的是,一個Web3產品卻在Web2的產品鏈上瘋狂傳銷,各方大佬紛紛為其背書,到底發生了什么?Damus的葫蘆里,賣的是什么藥? 注冊和簡單實用 很少有什么產品在用戶注冊環節會有什么噱頭,但Damus確實出 ......

    uj5u.com 2023-02-05 06:48:39 more