罗翔说刑法:律师该如何为“坏人”辩护(代码片段)

ukzq ukzq     2022-12-06     281

关键词:

https://daily.zhihu.com/story/9725762
柏拉图在《理想国》中就告诉人们,正义不仅本身值得追究,其结果也往往合乎欲求。一种正当的技艺不仅有其独特的追求,同时也能带来附随的好处。正如医生要追求医术高明妙手回春,而这种追求同时也能带来良好的声誉与可观的收入,这没有什么不道德。但如果医生只是追名逐利,为了名利可以放弃医疗职业本身的追求,那么医生也就不再是医生,他放弃了医术这种特定的技艺。同样,律师的辩护也是一种独特的技艺,他应该在每个个案中追寻正义,如果律师只是为了追逐当事人的最大利益,实现名利的最大化,那么律师的辩护也就不再是一种正当的技艺。


import java.lang.reflect.Method;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.Signature;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.aspectj.lang.reflect.MethodSignature;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.servlet.HandlerMapping;
import com.alibaba.fastjson.JSON;


/**
 * 操作日志记录处理
 * 
 */
@Aspect
@Component
public class LogAspect

    private static final Logger log = LoggerFactory.getLogger(LogAspect.class);

    // 配置织入点
    @Pointcut("@annotation(com.xxx.framework.aspectj.lang.annotation.Log)")
    public void logPointCut()
    
    

    /**
     * 处理完请求后执行
     *
     * @param joinPoint 切点
     */
    @AfterReturning(pointcut = "logPointCut()", returning = "jsonResult")
    public void doAfterReturning(JoinPoint joinPoint, Object jsonResult)
    
        handleLog(joinPoint, null, jsonResult);
    

    /**
     * 拦截异常操作
     * 
     * @param joinPoint 切点
     * @param e 异常
     */
    @AfterThrowing(value = "logPointCut()", throwing = "e")
    public void doAfterThrowing(JoinPoint joinPoint, Exception e)
    
        handleLog(joinPoint, e, null);
    

    protected void handleLog(final JoinPoint joinPoint, final Exception e, Object jsonResult)
    
        try
        
            // 获得注解
            Log controllerLog = getAnnotationLog(joinPoint);
            if (controllerLog == null)
            
                return;
            

            // 获取当前的用户
            LoginUser loginUser = SpringUtils.getBean(TokenService.class).getLoginUser(ServletUtils.getRequest());

            // *========数据库日志=========*//
            SysOperLog operLog = new SysOperLog();
            operLog.setStatus(BusinessStatus.SUCCESS.ordinal());
            // 请求的地址
            String ip = IpUtils.getIpAddr(ServletUtils.getRequest());
            operLog.setOperIp(ip);
            // 返回参数
            operLog.setJsonResult(JSON.toJSONString(jsonResult));

            operLog.setOperUrl(ServletUtils.getRequest().getRequestURI());
            if (loginUser != null)
            
                operLog.setOperName(loginUser.getUsername());
            

            if (e != null)
            
                operLog.setStatus(BusinessStatus.FAIL.ordinal());
                operLog.setErrorMsg(StringUtils.substring(e.getMessage(), 0, 2000));
            
            // 设置方法名称
            String className = joinPoint.getTarget().getClass().getName();
            String methodName = joinPoint.getSignature().getName();
            operLog.setMethod(className + "." + methodName + "()");
            // 设置请求方式
            operLog.setRequestMethod(ServletUtils.getRequest().getMethod());
            // 处理设置注解上的参数
            getControllerMethodDescription(joinPoint, controllerLog, operLog);
            // 保存数据库
            AsyncManager.me().execute(AsyncFactory.recordOper(operLog));
        
        catch (Exception exp)
        
            // 记录本地异常日志
            log.error("==前置通知异常==");
            log.error("异常信息:", exp.getMessage());
            exp.printStackTrace();
        
    

    /**
     * 获取注解中对方法的描述信息 用于Controller层注解
     * 
     * @param log 日志
     * @param operLog 操作日志
     * @throws Exception
     */
    public void getControllerMethodDescription(JoinPoint joinPoint, Log log, SysOperLog operLog) throws Exception
    
        // 设置action动作
        operLog.setBusinessType(log.businessType().ordinal());
        // 设置标题
        operLog.setTitle(log.title());
        // 设置操作人类别
        operLog.setOperatorType(log.operatorType().ordinal());
        // 是否需要保存request,参数和值
        if (log.isSaveRequestData())
        
            // 获取参数的信息,传入到数据库中。
            setRequestValue(joinPoint, operLog);
        
    

    /**
     * 获取请求的参数,放到log中
     * 
     * @param operLog 操作日志
     * @throws Exception 异常
     */
    private void setRequestValue(JoinPoint joinPoint, SysOperLog operLog) throws Exception
    
        String requestMethod = operLog.getRequestMethod();
        if (HttpMethod.PUT.name().equals(requestMethod) || HttpMethod.POST.name().equals(requestMethod))
        
            String params = argsArrayToString(joinPoint.getArgs());
            operLog.setOperParam(StringUtils.substring(params, 0, 2000));
        
        else
        
            Map<?, ?> paramsMap = (Map<?, ?>) ServletUtils.getRequest().getAttribute(HandlerMapping.URI_TEMPLATE_VARIABLES_ATTRIBUTE);
            operLog.setOperParam(StringUtils.substring(paramsMap.toString(), 0, 2000));
        
    

    /**
     * 是否存在注解,如果存在就获取
     */
    private Log getAnnotationLog(JoinPoint joinPoint) throws Exception
    
        Signature signature = joinPoint.getSignature();
        MethodSignature methodSignature = (MethodSignature) signature;
        Method method = methodSignature.getMethod();

        if (method != null)
        
            return method.getAnnotation(Log.class);
        
        return null;
    

    /**
     * 参数拼装
     */
    private String argsArrayToString(Object[] paramsArray)
    
        String params = "";
        if (paramsArray != null && paramsArray.length > 0)
        
            for (int i = 0; i < paramsArray.length; i++)
            
                if (!isFilterObject(paramsArray[i]))
                
                    Object jsonObj = JSON.toJSON(paramsArray[i]);
                    params += jsonObj.toString() + " ";
                
            
        
        return params.trim();
    

    /**
     * 判断是否需要过滤的对象。
     * 
     * @param o 对象信息。
     * @return 如果是需要过滤的对象,则返回true;否则返回false。
     */
    public boolean isFilterObject(final Object o)
    
        return o instanceof MultipartFile || o instanceof HttpServletRequest || o instanceof HttpServletResponse;
    



深入理解委托——为什么c#要引入委托(代码片段)

...活中,如果如果我们需要打官司,在法庭上是由律师为我们辩护的,然而律师真真执行的是当事人的陈词,这时候律师就是一个委托对象,当事人委托律师这个对象去帮自己辩护。这就是我们生活中委托的例... 查看详情

openai再获100亿美元?donotpay力砸100万仅为ai律师辩护复述;新冠四种亚型被机器学习算法进行归纳...

本周AI界又有哪些新鲜事?基础核心超聚变服务器操作系统新版FusionOS 23发布1月12日,“超聚变2023新品发布会”在北京举行。公司算力服务领域总裁郝峰会议上做了《桥接南北,融合生长,加速算力释放》的主题... 查看详情

html为昆汀哈迪辩护破坏结局(代码片段)

查看详情

csharp针对c#的行动辩护人(代码片段)

查看详情

我该如何为这种情况编写存储库方法?

】我该如何为这种情况编写存储库方法?【英文标题】:HowcanIwritearepositorymethodforthissituation?【发布时间】:2021-07-1816:02:39【问题描述】:我知道这不是定义汽车类的最佳方式,但我很好奇,最后写了这个:@Entity@Table(name="CAR")publ... 查看详情

行贿罪受贿罪刑事辩护6大要点

...属于对向犯,收受贿赂的主体同时也是行贿的对象,我国刑法根据受贿主体和行贿对象的不同设置了不同的罪名,以打击各类贿赂犯罪。例如,国家工作人员受贿构成受贿罪,对国家工作人员行贿则构成行贿罪;国有性质单位受... 查看详情

cisco实战——不让坏人登陆设备(代码片段)

设置密码方法1:(config-line)#linevty04#设置远程连接数,允许从0到4一共五个连接数(config-line)#password123#设置远程登录(即telnet)密码为123(config-line)#login#开启远程登录密码验证方法2:(config-line)#linevty04#设置远程连接数,允许从0到4... 查看详情

openai再获100亿美元?donotpay力砸100万仅为ai律师辩护复述;新冠四种亚型被机器学习算法进行归纳...

本周AI界又有哪些新鲜事?基础核心超聚变服务器操作系统新版FusionOS 23发布1月12日,“超聚变2023新品发布会”在北京举行。公司算力服务领域总裁郝峰会议上做了《桥接南北,融合生长,加速算力释放》的主题... 查看详情

ai律师出道,「倒贴」100万美元帮人类打官司

...量子位|公众号QbitAI悬赏100万美元,如果你用我们的AI律师在最高法院上帮你辩护。就在今天,来自美国一家机器人律师公司的CEO发了这样一条抓人眼球的消息。瞬间,网友们就炸开了锅。“什么?AI已经可以帮人... 查看详情

在座的python爬虫工程师,你敢爬律师事务所站点吗?(代码片段)

...⛳️实战场景本次要分析的站点是credit.acla.org.cn/,一个律师群体常去的站点,作为一个爬虫工程师,这简直是送自己去喝茶。该站点反爬手段特别多,分析起来也特别有趣。⛳️反爬实战打开开发者工具,无限debugger(functionanonym... 查看详情

在座的python爬虫工程师,你敢爬律师事务所站点吗?(代码片段)

...⛳️实战场景本次要分析的站点是credit.acla.org.cn/,一个律师群体常去的站点,作为一个爬虫工程师,这简直是送自己去喝茶。该站点反爬手段特别多,分析起来也特别有趣。⛳️反爬实战打开开发者工具,无限debugger(functionanonym... 查看详情

“腾讯老干妈事件”后续,一审宣判,主犯获刑12年(代码片段)

...分别被判处有期徒刑12年、7年、6年。被告人曹某的辩护律师尹姮表示&#x 查看详情

线程池中某个线程执行有异常,该如何处理?(代码片段)

目录1.线程池抛出异常代码`executorService.submit`没有打印出异常2.如何获取和处理异常方法1:线程自身打印异常方法2:使用Thread.setUncaughtExceptionHandler设置线程自己的异常处理附:java.util.concurrent.ThreadPoolExecutor#runWorker方法3:... 查看详情

辩护人

  昨晚看了韩剧辩护人,说句实话,我还是第一次看电影结束后的字幕那部分,准确说是享受那段音乐,自己脑海中不断浮现结束的各种片段,为了那个看似遗憾但是却完美无憾的结局而献上自己最为崇高的敬意;  电影前... 查看详情

我的灵魂永不下跪

...认为是犯罪凶手,其实最大的原因是由于他是黑人,辩护律师为了给他辩护而说他是猪,但还是被认定为有罪被处以电刑,他本人也是相当的消极,认为自己就是一头待宰的猪,而他 查看详情

请问下在javajdbc中:sql语句中含有or时,该如何为这个占位符(?)赋值····求解如下图:

比如说:通过一个或多个条件来查询时,则从数据库中读取与之相符的一条或多条数据参考技术A无论怎样,通配符都是遵循这循序来的,JDBC从0开始,hibernate从1开始。 参考技术B为问号占位符赋值只和位置有关系,和写在哪里无... 查看详情

hdu1443joseph---约瑟夫环(代码片段)

...m.php?pid=1443题目大意:一共有2k个人,分别为k个好人和k个坏人,现在我们需要每隔m个人把坏人挑出来,但是条件是最后一个坏人挑出来前不能有好人被挑出来。。问最小的m是多少。k最大为13.思路:由于k的数值较小,直接打表... 查看详情

codeforcesround#747(div.2)d.thenumberofimposters(并查集,二分图)(代码片段)

...非两种情况.Ⅰ.AAA是好人说真话,那么BBB也是好人Ⅱ.AAA是坏人说假话,那么BBB也是坏人抽象出来也就是A,BA,BA,B属于同一类而当AAA说BBB是坏人时,也就是A,BA,BA,B属于不同的类我们可以用并查集先对形如"AAA说BBB是好人"这种关系处... 查看详情