- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试使用 Python PIL 为黑白图像编写基本的隐写术算法。
使用示例图像,我可以成功地提取其中的隐藏图像,并隐藏其他图像以随后提取它们。问题在于隐藏文本然后将其提取出来。
from PIL import Image
import matplotlib.pyplot as plt
import scipy.misc as sci
import numpy as np
import array
#CONVERTS IMAGE TO ARRAY OF BINARY 8-BIT NUMBER#
def getImgArray(image):
w,h = image.size
out = []
for x in range(w):
for y in range(h):
pixel = image.getpixel((y,x))
pixel = format(pixel, '08b')
out.append(pixel)
return out
def stringByteConverter(data, mode):
if (mode == "stringToByte"):
aux = map(ord,data.encode('utf8'))
aux = [format(char,'08b') for char in aux]
return aux
elif (mode == "byteToString"):
aux = [int(item,2) for item in data]
aux = "".join(map(chr, aux))
return aux
else:
print("Invalid mode. Use 'stringToByte' or 'byteToString'")
#GETS HIDDEN IMAGE AND RETURNS IT AS BYTE ARRAY REPRESENTING PIXELS#
def getHiddenImage(image):
buf = ""
width,height = image.size
img_aux = []
for x in range(width):
for y in range(height):
if(len(buf)<8):
pixel = image.getpixel((y,x))
pixel = format(pixel,'08b')
buf += pixel[-2:]
else:
img_aux.append(buf)
buf = ""
pixel = image.getpixel((y,x))
pixel = format(pixel,'08b')
buf += pixel[-2:]
return img_aux
#CONVERT ARRAY OF BYTES TO PNG IMG AND RETURNS PIL IMG OBJECT#
def saveImgArr(ImgArr, size, outputName):
pixels = np.empty(size)
iterator = 0
for i in range(size[0]):
for j in range(size[1]):
try:
pixels[i][j] = int(ImgArr[iterator],2)
iterator += 1
except IndexError:
break
aux = Image.fromarray(pixels)
aux = aux.convert("L")
aux.save(outputName+'.png', 'PNG')
return pixels
#HIDE IMAGE <src> IN OTHER IMAGE <img>#
def hideImg(src, img, output):
iterator = 0
src = src.convert("L")
srcArr = getImgArray(src)
imgArr = getImgArray(img)
for i in range(len(srcArr)):
buf = []
buf.append(srcArr[i][:2])
buf.append(srcArr[i][2:4])
buf.append(srcArr[i][4:6])
buf.append(srcArr[i][6:])
for j in range(4):
imgArr[iterator] = imgArr[iterator][:-2] + buf[j]
iterator += 1
saveImgArr(imgArr,img.size,output)
#HIDE STRING INSIDE IMG#
def hideText(img, string, outputName):
imgArr = getImgArray(img)
stringBytes = stringByteConverter(string, "stringToByte")
iterator = 0
for i in range(len(string)):
buf = []
buf.append(stringBytes[i][:2])
buf.append(stringBytes[i][2:4])
buf.append(stringBytes[i][4:6])
buf.append(stringBytes[i][6:])
for j in range(4):
imgArr[iterator] = imgArr[iterator][:-2] + '00'
imgArr[iterator] = imgArr[iterator][:-2] + buf[j]
iterator += 1
print(imgArr[:len(string)*4]) #test print
saveImgArr(imgArr,img.size,outputName)
temp = Image.open(outputName+'.png')
tempArr = getImgArray(temp)
print(tempArr[:len(string)*4]) #test print
def getHiddenText(img, msgSize):
buf = ''
width,height = img.size
output = []
counter = 0
for x in range(width):
for y in range(height):
if(counter < msgSize*4):
pixel = img.getpixel((y,x))
pixel = format(pixel,'08b')
buf += pixel[-2:]
counter += 1
output = stringByteConverter(buf, "byteToString")
return output
通过在 hideText() 函数中打印数据数组,我能够获得以下内容:
hideText(lena,'test',"lena_hidden_text")
['10100001', '10100011', '10100001', '10100000', '10100001', '10011110', '10100001', '10100001', '10100101', '10100011', '10100000', '10011111', '10011001', '10100011', '10011101', '10011000']
['10011110', '10100000', '10011110', '10011101', '10011110', '10011011', '10011110', '10011110', '10100011', '10100000', '10011101', '10011100', '10010101', '10100000', '10011001', '10010100']
通过 hideText() 调用获得的第一个向量与它应该的完全一样,但是在使用 saveImgArr() 保存图像并使用 getImgArr() 重新加载之后,返回的第二个向量完全不同。
我这辈子都找不到问题所在。这很奇怪,因为使用图像提取隐藏数据或隐藏数据,这两个功能都能完美运行。
我只能猜测我处理的文本字节在某种程度上是错误的。任何见解将不胜感激。
最佳答案
在 saveImgArr 中有一件看起来可疑的事情:
aux = Image.fromarray(pixels)
aux = aux.convert("L")
默认mode对于 Image.fromarray使用是从输入的数据类型推导出来的。
在您的情况下,输入的数据类型是 numpy 的默认数据类型( float ),因此图像将基于 float 构造。因此,我预测保存的 png 图像看起来不正确(只是一个空白图像,因为每个像素都会饱和到 1.0)。
要更正此问题,您可以向 numpy 提供正确的数据类型,即更改:
pixels = np.empty(size)
到
pixels = np.empty(size,dtype='uint8')
或通过更改显式地向 Image.fromarray 提供模式:
aux = Image.fromarray(pixels)
aux = aux.convert("L")
到
aux = Image.fromarray(pixels,mode='L')
关于python - 使用 Python PIL 的隐写算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41533016/
在 python 解释器中: >>> import PIL >>> PIL.Image Traceback (most recent call last): File "", line 1, in
我在 Pillow 中遇到过这个奇怪的错误,其中导入名称 PIL 需要全部小写而不是全部大写,但我从未见过 pil在任何地方都使用小写字母。这意味着我使用的导入 PIL 的所有 python 包和文件
有没有办法使用 PIL 截取驻留在我的服务器上的指定 HTML/Javascript 页面的屏幕截图? 我想编写一个脚本来更改该 HTML 页面上的一些参数,然后让 PIL 对其进行屏幕截图。 有什么
这是我所做的描述。 我正在尝试使用 PIL 编写程序,但是在尝试导入它时(如下所示),出现错误(也如下所示)。 from PIL import Image Here is the error. Tra
我正在尝试对图像进行简单的裁剪。这是代码 from PIL.Image import Image def get_image_half(image, half="upper"): if hal
我是一名新的Python用户,也是“Stack Overflow”中的新用户,当我尝试编译 tensorflow 代码时,我遇到了一些问题,并且我无法从网站上找到答案,所以我想从这里获得一些帮助,先谢
我知道 stackoverflow 上已经有很多与此问题相关的问题,我已经阅读了所有问题,但我仍然没有成功解决此问题。我希望有人能帮我解决这个问题。 我已经安装并重新安装了 Pillow 10 次。我
我得到错误: --------------------------------------------------------------------------- ImportError
我是机器学习的初学者,所以我试图创建一个模型来识别 Keras 博客中引用的图像。我已经在 Windows 10 上安装了 Anaconda 3 以及所有软件包,如tensorflow、keras、s
我正在尝试使用过滤器 FIND_EDGES 从图片中获取边缘,它在我的 Windows PC 上工作,但是当我在我的 Raspberry Pi 上运行相同的代码时,它给出了图像模式错误的错误。 最佳答
这个问题在 Python 环境中有一些答案,但这些解决方案不适用于我的 RStudio 环境。这是我的代码: library(keras) library(tensorflow) use_condae
我正在使用 Mac OS x 10.10.3 Yosemite 和 Python 2.7.9 |Anaconda 2.2.0 (x86_64) 来处理很多 python 的东西。我正在使用 Eclip
我正在遵循这个 SageMaker 指南并使用 1.12 cpu docker 文件。 https://github.com/aws/sagemaker-tensorflow-serving-cont
`from PIL import Image, ImageDraw, ImageFont image = Image.new('RGB', (950, 250), color=(255, 255, 2
我知道如何从图片中找到边缘。但我希望轮廓边缘更厚,例如宽度 9。 from PIL import Image, ImageFilter image = Image.open('your
我有多个白色背景的 PNG 图像,并且图像的某些部分充满了图案(可能是不同的颜色,黑色、蓝色、红色、黄色等)。 如何使用 Python PIL 库将所有这些图像合并为一张图像,以便所有非白色部分出
目前我正在尝试裁剪以下地址下文件夹内的所有图像:C:\\Users\\xie\\Desktop\\tiff\\Bmp然后将它们重新保存到同一个文件夹中。下面是我试图试验的代码,两者都运行没有错误但什么
虽然它们非常相似,但我确信 Pearson 相关相似度和调整余弦相似度之间存在一些差异,因为所有的论文和网页都将它们分为两种不同的类型。 然而,它们都没有提供明确的定义。 Here是其中一页。 谁能说
这是我的forms.py: class UploadImageForm(forms.ModelForm): class Meta: model = UserImages
关闭。这个问题需要更多 focused .它目前不接受答案。 想改进这个问题?更新问题,使其仅关注一个问题 editing this post . 4年前关闭。 Improve this questi
我是一名优秀的程序员,十分优秀!