A generic error occurred in GDI+

  1. 因为 .net GDI+ 是对底层 的封装。 所以可以尝试用 Marshal.GetLastWin32Error();函数获得底层错误代码
try{
   image.Save(filename, System.Drawing.Imaging.ImageFormat.Png);
} 
catch (Exception exp)
            {
                var code = Marshal.GetLastWin32Error();
                throw new Exception(exp.Message + ":" + code.ToString(), exp);
            }

2. 查看错误代码含义

ERROR_PATH_NOT_FOUND

3 (0x3)

The system cannot find the path specified.

原因:save的目录不存在。解决:手动或通过程序建save的目录。

ERROR_ACCESS_DENIED

5 (0x5)

Access is denied.

原因: save的目录没有权限

解决: 查看目录的权限

ERROR_SHARING_VIOLATION32 (0x20)

The process cannot access the file because it is being used by another process.

原因:

  从一个文件构造的Bitmap 对象或一个 Image 对象, 在该对象的生存期内该文件处于锁定状态。 因此, 在没有释放这个Image或Bitmap对象前,无法更改图像并将其保存回原文件。

  解决方法:

解决:

构造一个新的Image对象,然后把原来的Image对象中的图象通过Graphics的DrawImage()方法,拷贝到新Image对象中,最后通过Dispose()方法释放原来的Image对象:

  Image image = new Bitmap ( openFileDialog1 . FileName );

  //新建第二个Image类型的变量newImage,这里是根据程序需要设置自己设置。

  Image newImage = new Bitmap ( 800 , 600 );

  //将第一个bmp拷贝到bmp2中

  Graphics draw = Graphics . FromImage ( newImage);

  draw . DrawImage ( image , 0 , 0 );

  //释放第一个Image对象

  image.Dispose();

 3.其他问题

a.  Image 对应的Stream被Dispose了。

b.  保存成png时报错。

转载自` https://www.cnblogs.com/guangfengli/p/5920104.html `

maven发布的项目打包jsp

从eslipse迁移的Web项目的jsp、js、css等文件都是放到WebContent里,而Maven中,这些文件是放到webapp下的。所以,如果你直接用Maven进行install也就是打包的时候,你的页面相关的文件不会被打包进去,你会发现打好的war包里只有src下的.class文件和一些配置文件。那么如何将页面等文件也包含进去呢?

<build>
	<finalName>projectName</finalName>
	<plugins>
		<plugin>
			<groupId>org.apache.maven.plugins</groupId>
			<artifactId>maven-war-plugin</artifactId>
			<version>3.2.3</version>					
			<configuration>
				<!--指定web.xml文件的位置-->
				<webXml>WebContent/WEB-INF/web.xml</webXml>				
				<!--指定jsp等文件所在位置-->   
				<warSourceDirectory>WebContent</warSourceDirectory>
			</configuration>
		</plugin>
	</plugins>
</build>

批量 修改 数据库的字符集和排序规则

-- 字符集为utf8mb4,排序规则为utf8mb4_unicode_ci

-- 修改数据库
ALTER DATABASE 数据库名 CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

-- 设置每张表的字符集和排序规则为为 utf8mb4、utf8mb4_unicode_ci
SELECT CONCAT('ALTER TABLE ', table_name, ' CONVERT TO CHARACTER SET  utf8mb4 COLLATE utf8mb4_unicode_ci;')
FROM information_schema.TABLES
WHERE TABLE_SCHEMA = '数据库名';

-- 批量修改字符编码和排序编码
select concat('ALTER TABLE `', table_name, '` MODIFY `', column_name, '`', DATA_TYPE, '(', CHARACTER_MAXIMUM_LENGTH,
              ') CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci', ';')
FROM information_schema.COLUMNS
WHERE table_schema = '数据库名'
  AND DATA_TYPE IN ('varchar' ,'char');