idea 导入spring5.2.x源码并测试

相关资源版本

idea:2021
JDK:1.8
gradle:5.6.4(具体依据spring源码中的要求版本)
spring:5.2.x(不建议使用最新版本)
git:2.7.3(无版本要求)
系统:win10

获取源码

git clone -b 5.2.x https://github.com/spring-projects/spring-framework.git
或者使用
git clone https://github.com/spring-projects/spring-framework.git
然后切换到5.2.x的分支,容易忘记切换分支,然后下载的是最新代码,不容易导入成功
可以进入spring-framework目录,然后在gradle.properties文件中查看当前使用的spring版本,

image.png

git checkout 5.2.x

配置gradle

1、打开https://gradle.org/releases进行下载,一定要下载对应版本的gradle,才能编译成功,可以进入spring-framework-》gradle-》wrapper目录中,查看gradle-wrapper.properties文件中gradle版本信息

image.png

2、配置gradle环境变量GRADLE_HOME、GRADLE_USER_HOME、path,GRADLE_USER_HOME可以使用maven的仓库

使用idea打开源码

1、打开idea,然后
image.png

选择spring-project中的build.gradle文件,
image.png

导入项目后gradle使用jdk8,
image.png

导入后,项目会构建比较慢
2、打开build.gradle文件,在文件头部加上Spring插件库
这个就相当于是maven的pom文件)

repositories {
maven { url 'https://repo.spring.io/plugins-release-local' }
}
}
image.png

3、bulid.gradle文件添加阿里镜像,注意添加文件的位置及顺序

maven { url 'https://maven.aliyun.com/nexus/content/groups/public/' }
maven { url 'https://maven.aliyun.com/nexus/content/repositories/jcenter' }

maven { url "https://repo.springsource.org/plugins-release" }

4、保存后等待下载依赖
都修改好之后,保存一下,点击页面下图刷新图标,等待项目下载依赖构建即可,如果有报错多刷新几遍


image.png

对源码进行编译

1、先编译spring-oxm下的compileTestjava,选中双击即可,编译完成出现BUILD SUCCESSFUL代表编译完成


image.png

2、再编译下spring-core模块,因为之后的spring-context依赖于core,方法同上


image.png

3、都编译完成且成功之后,最后开始编译整个工程(这个过程非常耗时间),打开顶层项目spring->build->build,双击开始编译


image.png

测试基本功能

都编译成功之后,可以添加一个测试模块进来,进行测试源码构建编译是否真的完成

1、新建测试modle,步骤:【File】->【New】->【Module…】 在Spring中添加自己的module模块,同样选择gradle构建。


image.png

image.png

2、添加依赖
找到我们自己的测试模块test,打开build.gradle文件(相当于是pom文件),默认 dependencies依赖(这里的dependencies和maven里的依赖是一样的)我们需要手工添 加spring-context,spring-beans,spring-core,spring-aop这4个核心模块,具体如下

dependencies {
    //添加完要构建一下,否则代码中无法引用,注意不要忘了
    compile(project(":spring-context"))
    compile(project(":spring-beans"))
    compile(project(":spring-core"))
    compile(project(":spring-aop"))

    testCompile group: 'junit', name: 'junit', version: '4.12'
}

3、添加完成依赖后,需要对测试modle进行构建,构建完成后,才能正常使用


image.png

构建后的项目情况截图:


image.png

编写测试代码

下面编写一个简单的applicationContext获取容器用的bean,主要是测试Spring源码构建编译过程是否成功!
1、下面编写一个简单的applicationContext获取容器用的bean,主要是测试Spring源码构建编译过程是否成功!

package com.clf;
public class User {
    private String id;
    private String userName;
    public User() {
    }
    public User(String id, String userName) {
        this.id = id;
        this.userName = userName;
    }
    public String getId() {
        return this.id;
    }
    public void setId(String id) {
        this.id = id;
    }
    public String getUserName() {
        return this.userName;
    }
    public void setUserName(String userName) {
        this.userName = userName;
    }
    @Override
    public String toString() {
        return "com.clf.User{" +
                "id='" + this.id + '\'' +
                ", userName='" + this.userName + '\'' +
                '}';
    }
}

2、新建JavaConfig.java


import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;

@Configuration
@ComponentScan
public class JavaConfig {
    @Bean
    public User user(){
        return new User("001","Jack");
    }
}

3、最后编写一个测试类Test.java


import org.springframework.context.annotation.AnnotationConfigApplicationContext;

public class Test {
    public static void main(String[] args) {
        System.out.println("hello");
        AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(JavaConfig.class);
        User user = (User) context.getBean("user");
        System.out.println(user.toString());
    }

}

4、运行Test类
注意: 运行时可能会报如下错误:

> Checkstyle rule violations were found. See the report at: file:///C:/chenlf/private_workspace/spring-framework/myTest/build/reports/checkstyle/main.html
  Checkstyle files with violations: 3
  Checkstyle violations by severity: [error:5]

出现以上错误是因为spring使用了ant风格的代码检查,所有的检查规则都在src/checkstyle/checkstyle.xml里面做了配置,如果不想被这些检查烦扰到,可以全部注释掉:


image.png
<!DOCTYPE module PUBLIC "-//Checkstyle//DTD Checkstyle Configuration 1.3//EN" "https://checkstyle.org/dtds/configuration_1_3.dtd">
<module name="com.puppycrawl.tools.checkstyle.Checker">
    <!-- Suppressions -->
    <!--    <module name="SuppressionFilter">-->
    <!--        <property name="file" value="${config_loc}/checkstyle-suppressions.xml"/>-->
    <!--    </module>-->

    <!--    &lt;!&ndash; Root Checks &ndash;&gt;-->
    <!--    <module name="io.spring.javaformat.checkstyle.check.SpringHeaderCheck">-->
    <!--        <property name="fileExtensions" value="java" />-->
    <!--        <property name="headerType" value="apache2"/>-->
    <!--        <property name="headerCopyrightPattern" value="20\d\d-20\d\d"/>-->
    <!--        <property name="packageInfoHeaderType" value="none"/>-->
    <!--    </module>-->
    <!--    <module name="com.puppycrawl.tools.checkstyle.checks.NewlineAtEndOfFileCheck">-->
    <!--        <property name="lineSeparator" value="lf"/>-->
    <!--    </module>-->

    <!--    &lt;!&ndash; TreeWalker Checks &ndash;&gt;-->
    <!--    <module name="com.puppycrawl.tools.checkstyle.TreeWalker">-->
    <!--        &lt;!&ndash; Annotations &ndash;&gt;-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.annotation.AnnotationUseStyleCheck">-->
    <!--            <property name="elementStyle" value="compact" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.annotation.MissingOverrideCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.annotation.PackageAnnotationCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.annotation.AnnotationLocationCheck">-->
    <!--            <property name="allowSamelineSingleParameterlessAnnotation"-->
    <!--                value="false" />-->
    <!--        </module>-->

    <!--        &lt;!&ndash; Block Checks &ndash;&gt;-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.blocks.EmptyBlockCheck">-->
    <!--            <property name="option" value="text" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.blocks.LeftCurlyCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.blocks.RightCurlyCheck">-->
    <!--            <property name="option" value="alone" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.blocks.NeedBracesCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.blocks.AvoidNestedBlocksCheck" />-->

    <!--        &lt;!&ndash; Class Design &ndash;&gt;-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.design.FinalClassCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.design.InterfaceIsTypeCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.design.HideUtilityClassConstructorCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.design.MutableExceptionCheck">-->
    <!--            <property name="format" value="^.*Exception$" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.design.InnerTypeLastCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.design.OneTopLevelClassCheck" />-->

    <!--        &lt;!&ndash; Type Names &ndash;&gt;-->
    <!--        <module name="TypeName">-->
    <!--            <property name="format" value="^[A-Z][a-zA-Z0-9_]*(?&lt;!com.clf.Test)$" />-->
    <!--            <property name="tokens" value="CLASS_DEF" />-->
    <!--            <message key="name.invalidPattern"-->
    <!--                value="Class name ''{0}'' must not end with ''com.clf.Test'' (checked pattern ''{1}'')." />-->
    <!--        </module>-->

    <!--        &lt;!&ndash; Coding &ndash;&gt;-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.coding.CovariantEqualsCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.coding.EmptyStatementCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.coding.EqualsHashCodeCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.coding.SimplifyBooleanExpressionCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.coding.SimplifyBooleanReturnCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.coding.StringLiteralEqualityCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.coding.NestedForDepthCheck">-->
    <!--            <property name="max" value="3" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.coding.NestedIfDepthCheck">-->
    <!--            <property name="max" value="5" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.coding.NestedTryDepthCheck">-->
    <!--            <property name="max" value="3" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.coding.MultipleVariableDeclarationsCheck" />-->

    <!--        <module name="io.spring.javaformat.checkstyle.filter.RequiresOuterThisFilter" />-->
    <!--        <module name="io.spring.javaformat.checkstyle.filter.IdentCheckFilter">-->
    <!--            <property name="names" value="logger" />-->
    <!--            <module-->
    <!--                name="com.puppycrawl.tools.checkstyle.checks.coding.RequireThisCheck">-->
    <!--                <property name="checkMethods" value="false" />-->
    <!--                <property name="validateOnlyOverlapping" value="false" />-->
    <!--            </module>-->
    <!--        </module>-->
    <!--        <module name="io.spring.javaformat.checkstyle.check.SpringNoThisCheck">-->
    <!--            <property name="names" value="logger" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.coding.OneStatementPerLineCheck" />-->

    <!--        &lt;!&ndash; Imports &ndash;&gt;-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.imports.AvoidStarImportCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.imports.RedundantImportCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.imports.UnusedImportsCheck">-->
    <!--            <property name="processJavadoc" value="true" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.imports.ImportOrderCheck">-->
    <!--            <property name="groups" value="java,javax,*,org.springframework" />-->
    <!--            <property name="ordered" value="true" />-->
    <!--            <property name="separated" value="true" />-->
    <!--            <property name="option" value="bottom" />-->
    <!--            <property name="sortStaticImportsAlphabetically" value="true" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.imports.IllegalImportCheck">-->
    <!--            <property name="id" value="bannedImports"/>-->
    <!--            <property name="regexp" value="true" />-->
    <!--            <property name="illegalClasses"-->
    <!--                value="^reactor\.core\.support\.Assert,^org\.slf4j\.LoggerFactory" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.imports.IllegalImportCheck">-->
    <!--            <property name="id" value="bannedJUnit3Imports"/>-->
    <!--            <property name="regexp" value="true" />-->
    <!--            <property name="illegalClasses" value="^junit\.framework\..+" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.imports.IllegalImportCheck">-->
    <!--            <property name="id" value="bannedJUnit4Imports"/>-->
    <!--            <property name="regexp" value="true" />-->
    <!--            <property name="illegalClasses"-->
    <!--                value="^org\.junit\.(com.clf.Test|BeforeClass|AfterClass|Before|After|Ignore|FixMethodOrder|Rule|ClassRule|Assert|Assume)$,^org\.junit\.(Assert|Assume)\..+,^org\.junit\.(experimental|internal|matchers|rules|runner|runners|validator)\..+" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.imports.IllegalImportCheck">-->
    <!--            <property name="id" value="bannedJUnitJupiterImports"/>-->
    <!--            <property name="regexp" value="true" />-->
    <!--            <property name="illegalClasses" value="^org\.junit\.jupiter\..+" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.imports.IllegalImportCheck">-->
    <!--            <property name="id" value="bannedTestNGImports"/>-->
    <!--            <property name="regexp" value="true" />-->
    <!--            <property name="illegalClasses" value="^org\.testng\..+," />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.imports.IllegalImportCheck">-->
    <!--            <property name="id" value="bannedHamcrestImports"/>-->
    <!--            <property name="regexp" value="true" />-->
    <!--            <property name="illegalClasses" value="^org\.hamcrest\..+" />-->
    <!--        </module>-->

    <!--        &lt;!&ndash; Javadoc Comments &ndash;&gt;-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.javadoc.JavadocTypeCheck">-->
    <!--            <property name="scope" value="package"/>-->
    <!--            <property name="authorFormat" value=".+\s.+"/>-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.javadoc.JavadocMethodCheck">-->
    <!--            <property name="allowMissingParamTags" value="true"/>-->
    <!--            <property name="allowMissingThrowsTags" value="true"/>-->
    <!--            <property name="allowMissingReturnTag" value="true"/>-->
    <!--            <property name="allowMissingJavadoc" value="true"/>-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.javadoc.JavadocVariableCheck">-->
    <!--            <property name="scope" value="public"/>-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.javadoc.JavadocStyleCheck">-->
    <!--            <property name="checkEmptyJavadoc" value="true"/>-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.javadoc.NonEmptyAtclauseDescriptionCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.javadoc.JavadocTagContinuationIndentationCheck">-->
    <!--            <property name="offset" value="0"/>-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.javadoc.AtclauseOrderCheck">-->
    <!--            <property name="target" value="CLASS_DEF, INTERFACE_DEF, ENUM_DEF"/>-->
    <!--            <property name="tagOrder" value="@author, @since, @param, @see, @version, @serial, @deprecated"/>-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.javadoc.AtclauseOrderCheck">-->
    <!--            <property name="target" value="METHOD_DEF, CTOR_DEF, VARIABLE_DEF"/>-->
    <!--            <property name="tagOrder" value="@param, @return, @throws, @since, @deprecated, @see"/>-->
    <!--        </module>-->

    <!--        &lt;!&ndash; Miscellaneous &ndash;&gt;-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.indentation.CommentsIndentationCheck">-->
    <!--            <property name="tokens" value="BLOCK_COMMENT_BEGIN"/>-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.UpperEllCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.ArrayTypeStyleCheck" />-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.OuterTypeFilenameCheck" />-->

    <!--        &lt;!&ndash; Regexp &ndash;&gt;-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.regexp.RegexpSinglelineJavaCheck">-->
    <!--            <property name="format" value="^\t* +\t*\S" />-->
    <!--            <property name="message"-->
    <!--                value="Line has leading space characters; indentation should be performed with tabs only." />-->
    <!--            <property name="ignoreComments" value="true" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.regexp.RegexpCheck">-->
    <!--            <property name="format" value="[ \t]+$" />-->
    <!--            <property name="illegalPattern" value="true" />-->
    <!--            <property name="message" value="Trailing whitespace" />-->
    <!--        </module>-->
    <!--        <module-->
    <!--            name="com.puppycrawl.tools.checkstyle.checks.regexp.RegexpSinglelineJavaCheck">-->
    <!--            <property name="maximum" value="0" />-->
    <!--            <property name="format"-->
    <!--                value="assertThatExceptionOfType\((NullPointerException|IllegalArgumentException|IOException|IllegalStateException)\.class\)" />-->
    <!--            <property name="message"-->
    <!--                value="Please use specialized AssertJ assertThat*Exception method." />-->
    <!--            <property name="ignoreComments" value="true" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.regexp.RegexpSinglelineJavaCheck">-->
    <!--            <property name="id" value="bddMockito"/>-->
    <!--            <property name="maximum" value="0"/>-->
    <!--            <property name="format" value="org\.mockito\.Mockito\.(when|doThrow|doAnswer)" />-->
    <!--            <property name="message" value="Please use BDDMockito." />-->
    <!--            <property name="ignoreComments" value="true" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.regexp.RegexpSinglelineJavaCheck">-->
    <!--            <property name="id" value="expectedExceptionAnnotation"/>-->
    <!--            <property name="maximum" value="0"/>-->
    <!--            <property name="format" value="\@com.clf.Test\(expected" />-->
    <!--            <property name="message" value="Please use AssertJ assertions." />-->
    <!--            <property name="ignoreComments" value="true" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.regexp.RegexpSinglelineJavaCheck">-->
    <!--            <property name="id" value="junit4Assertions"/>-->
    <!--            <property name="maximum" value="0"/>-->
    <!--            <property name="format" value="org\.junit\.Assert\.assert" />-->
    <!--            <property name="message" value="Please use AssertJ assertions." />-->
    <!--            <property name="ignoreComments" value="true" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.regexp.RegexpSinglelineJavaCheck">-->
    <!--            <property name="id" value="junitJupiterAssertions"/>-->
    <!--            <property name="maximum" value="0"/>-->
    <!--            <property name="format" value="org\.junit\.jupiter\.api\.Assertions\.assert" />-->
    <!--            <property name="message" value="Please use AssertJ assertions." />-->
    <!--            <property name="ignoreComments" value="true" />-->
    <!--        </module>-->
    <!--        <module name="com.puppycrawl.tools.checkstyle.checks.regexp.RegexpSinglelineJavaCheck">-->
    <!--            <property name="id" value="testNGAssertions"/>-->
    <!--            <property name="maximum" value="0"/>-->
    <!--            &lt;!&ndash; should cover org.testng.Assert and org.testng.AssertJUnit &ndash;&gt;-->
    <!--            <property name="format" value="org\.testng\.Assert(JUnit)?\.assert" />-->
    <!--            <property name="message" value="Please use AssertJ assertions." />-->
    <!--            <property name="ignoreComments" value="true" />-->
    <!--        </module>-->

    <!--        &lt;!&ndash; Spring Conventions &ndash;&gt;-->
    <!--        <module name="io.spring.javaformat.checkstyle.check.SpringLambdaCheck">-->
    <!--            <property name="singleArgumentParentheses" value="false" />-->
    <!--        </module>-->
    <!--        <module name="io.spring.javaformat.checkstyle.check.SpringCatchCheck" />-->
    <!--        <module name="io.spring.javaformat.checkstyle.check.SpringJavadocCheck" />-->
    <!--        <module name="io.spring.javaformat.checkstyle.check.SpringJUnit5Check" />-->
    <!--    </module>-->
</module>

去掉这些错误,错误就能解决,再次运行Test类,结果如下:



表明源码导入成功

导入源码,有太多的坑,参考文章:
https://blog.csdn.net/m0_37959155/article/details/126273608
https://blog.csdn.net/qq_25825005/article/details/122518377

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容