Giter Club home page Giter Club logo

spring-boot-controller-advice-aspect-handle-exception's Introduction

spring-boot-controller-advice-aspect-handle-exception

1- Log exception occurs at service layer to the database log table from @AfterThrowing advice.
2- Show a meaningful error message to the client by using @RestControllerAdvice.

Run with

Run: spring-boot-controller-advice-aspect-handle-exception > mvnw.cmd spring-boot:run

Tech Stack

Java 11
H2 Database Engine
spring boot
spring data jpa
spring web
spring aspects
hibernate
logback
maven
junit

API OPERATIONS

Save customer sucessfully to database

Method : HTTP.POST
URL : http://localhost:8080/customer/save

Request :

{ 
  "name":"name1",
  "age":1,
  "addresses":[
                {"streetName":"software","city":"ankara","country":"TR"}
              ]
}

Response :

HTTP response code 200

{
    "id": 1,
    "name": "name1",
    "age": 1,
    "addresses": [
        {
            "id": 1,
            "streetName": "software",
            "city": "ankara",
            "country": "TR"
        }
    ]
}

Create exception and trigger @AfterThrowing aspect. Insert log message into log table.

Method : HTTP.POST
URL : http://localhost:8080/customer/save

Request :

{
    "name": null,
    "age": null
}

Response :

HTTP response code 500

{
    "timestamp": "2021-04-13T19:29:07.112+00:00",
    "message": "not-null property references a null or transient value : com.company.customerinfo.model.Customer.age; nested exception is org.hibernate.PropertyValueException:   not-null property references a null or transient value : com.company.customerinfo.model.Customer.age",
    "details": "uri=/customer/save"
}

List entries in log table.

Method : HTTP.GET
URL : http://localhost:8080/log/list

Input Test Data : No input, just fire the request.

Request :

{
}

Response :

HTTP response code 200

[
    {
        "id": 1,
        "message": "org.hibernate.PropertyValueException: not-null property references a null or transient value : com.company.customerinfo.model.Customer.age"
    }
]

spring-boot-controller-advice-aspect-handle-exception's People

Contributors

tufangorel avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.